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Tbm ^pmpose in wri^g &fe biml£ is to jbstttxatice you to Ifhe sfgaife 
within the Apple®* II computer and to show you how these signals 
can be used to control external devices under the control of BASIC- 
language programs. A general-purpose eiJSnipttl^ tntSEtecies fefl^ltd- 
board has been developed to speed your circuit design and testing 
so that you can easily perform the many interesting experiments that 
are included in the book. By using a design systeilti mdi m &m «toe 
described in this book, you will spend your time concentrating on 
the principles involved, rather than troubleshooting your circuits. 
However, you will have the opportunity to build and test many digi- 
tal circuits, as well as circuits that me digital-to-analog and fuialpg- 
to-digital converters. 

We have chosen to use the Apple II computer with 16K of read/ 
write memory, and the Applesoft™t BASIC interpreter program, 
litis s^N^fe i^rd'viiSejs & ppekt lAtsi of fiexibitity and it is worth hav- 
ing it available when you are using external interface circuits. The 
Applesoft BASIC interpreter has two general-purpose commands 
tibat can be used to ttansfef fntermation to and from the computer. 
These instructions are easily mastered, without requiring a detailed 
understanding of the 6502 microprocessor integrated circuit (IC) 
ttiat is used as the "heart" of the Apple. 

First we will introduce you to the control signals that are available 
from the Apple computer for interfacing, and we will show you how 
they are used. Some of the signals will not be described, since they 
are generaJly not used in mterfei.<?e durcuits, and are meant to be used 
by spedltl ffifterf ace devf ces ttat ate rmtvoSketta^ed commercially. 

Our next step is to show you how the Apple can identify or address 
external devices through the use of two general-purpose instructions, 
VBEE and POKE. These commands are cenecal tbfe CHDntMl of ex- 
ternal devices; we spend some time covering t^Si operation and the 
use of a variety of circuits that can be used to identify specific input/ 
output, or I/O devices. TSdi^Klfll also see how the Apple can transfer 
ixt^raation to and from exCea^ devices over the bidirecticntal da^ 



*Apple and Apple II are registered trademarks of A|lfife CSfflpUtiSi; IbC, 
i Applesoft is a trademark of Apple Computer, Inc. 



bus; the basic circuits used for input ports and output ports are de- 
scribed in detail. Real circuits are provided, so that you can quickly 
use the many examples in designing your own interface devices. 

You will also see the power of BASIC-language programs— as the 
data is processed within the computer to provide meaningful results. 
Simple control programs are provided to show you how RASTC-lan- 
guage programs and I/O devices can interact. You will be able to 
write simple control and data processing programs to go along with 
your I/O ports and devices. 

Since the computer is not always synchronized to external devices, 
there must be some interaction between the computer and the vari- 
ous I/O devices so that each knows when the other is ready for some 
appropriate action. This leads us to the topic of flags— those signals 
that are used by the computer and by external I/O devices to allow 
information to be transferred in an orderly fashion. Since flags are 
important, we spend some time on them and on the corresponding 
circuits that are actually used in external devices. Software is covered 
too, since the flag circuits are useless unless they can be sensed by a 
control program. 

We have assumed that you have a fairly good understanding of the 
commands in Applesoft BASIC. If you are just getting started with 
the Apple computer, we hope that you will take some time to review 
the simple commands, such as FOR, GOTO, IF . . . THEN, PRINT, 
and INPUT. Other commands will be introduced in the text and ex- 
periments, and we will provide the details of their operation. At the 
end of this book, the use of these and other commands should be 
second-nature. 

In Chapter 6, we have provided 16 detailed, step-by-step experi- 
ments that you can perform to reinforce the many interfacing prin- 
ciples that have been developed in the text. You will also see the 
power of BASIC-language programs for interface control and for 
actually processing the information that is involved in transfers to 
and from I/O devices. We have made an elfort to cover a broad spec- 
trum of interesting interface applications. Throughout the experi- 
ments, you will see that the same basic principles apply to all of the 
interface circuits, from the simplest to the most complex. 

We realize that it is diflScult to write a book like this for an audi- 
ence that has a wide range of backgrounds, from the beginner to the 
advanced user. Thus, we have chosen to start at some middle point. 
We have chosen to skip basic binary numbering, decimal-to-binary 
conversions, basic digital electronics, and breadboarding. These top- 
ics are covered in detail in other books, and the reader who is in the 
middle of our assumed spectrum of readers probably has a good 
understanding of these topics. In some places, a paragraph or two of 
review material have been provided, just to serve as a refresher. We 



make no attempt to provide much detail here, simply enough to get 
you started. 

We have assumed some familiarity with SN7400-family digital in- 
tegrated circuits, or chips, such as the SN7402 quad nor gate and the 
SN7475 quad latch chip. Other complex chips will be introduced and 
explained in sufficient detail so that you can use them as shown in 
the text or experiments. If you wish to use these devices in other 
applications, we suggest that you obtain the necessary data sheets 
from the manufacturers. The data sheets will provide the necessary 
information for a wide variety of uses, and they will also reflect any 
basic changes or modifications that may have been made to an "up- 
dated" device, or one that has been "enhanced" with some special 
feature. 

The Apple II computer has eight general-piirpose 50-conductor 
interface connectors in its case. The basic bus signals used in the ex- 
periments are derived from the signals at these connectors, so if you 
decide to design and build some of your own interface circuits that 
will be plugged into one of these "slots," you will find the same sig- 
nals are readily available at the edge connectors. However, there are 
also some special-purpose signals that are generated by the Apple to 
make the interfacing ta.sk somewhat easier. These signals and their 
uses are described in detail in Chapter 7. Since the signals are not 
general purpose, but are specific to the Apple, and in many cases, 
specific to a particular connector, they are described last, To show 
you how these signals are used, a simple asynchronous-serial com- 
munication interface circuit is described, and software to control it 
is listed. This type of interface can be used to communicate with 
other computers, serial printers, modems, and other interface devices 
that use the asynchronous -serial data format. 

We have not described assembly-language programming, since 
this is a specialized topic and requires a great deal of background. 
However, we have provided one simple assembly-language subrou- 
tine for you to use in several of the experiments. There is a good 
reason for including this subroutine; the equivalent function is not 
readily available in Applesoft. The function required is the logical 
ANDing of 8-bit bytes. The logical and in Applesoft is simply a true- 
or-false and operation, and it cannot be easily used for bit ANDing. 
The assembly-language subroutine also provides you with an intro- 
duction to how such routines can be accessed by a BASIC-language 
program. We have chosen to use the more complicated USR(X) 
command, rather than the CALL command, since we think that 
more vdll be learned. 

We found that there were some limitations to the Apple. For ex- 
ample, there is no simple "rounding" command that can be used to 
round a number to a specific number of decimal digits, for example 



4.1986 to 4.20. Likewise, the absence of a bit-by-bit ANning command 
was a limitation that was overcome with an assembly-language rou- 
tine. We also found that the potentially useful WAIT command that 
is used to test individual bits will "hang up" the computer if the con- 
dition is not found. The computer continues to wait if the condition 
is not met, and you must reset the computer to get your program 
going again. A color display and nice graphics are available, al- 
though we used a black/ white monitor in our system. 

Most of the special purpose chips, such as the analog converters, 
have been chosen because of their simplicity, low cost, and avail- 
ability. This is not meant to be an endorsement of these products. As 
your interfacing sophistication increases, you will find other special- 
purpose devices that can serve the same function, but perhaps with 
added features, more resolution, different power supplies, etc. Our 
aim is to get you started, and not to provide you with a sourcebook 
of every possible interface to the Apple computer system. An impos- 
sible task in any case. 

If you are interested in some additional reading about more ad- 
vanced topics, we recommend: 

6502 Software Design (21656). 

Programming ir Interfacing the 6502, With Experiments (21651). 
Microcomputer-Analog Converter Software and Hardware Inter- 
facing (21540). 

We also recommend TRS-80 Interfacing, Book 2. While written 
around the TRS-80 computer, this book details more advanced inter- 
facing topics such as driving high-current/high-voltage loads, serial 
communications, remote control, analog converters, filtering and 
data processing, and other interesting topics. You will quickly see 
that the similarities between the TRS-80 and Apple are much greater 
than their dtflferences. Control signals and BASIC commands are al- 
most identical. All of the books noted above are available from 
Howard W. Sams & Co., Inc., 4300 West 62nd Street, Indianapolis, 
IN 46268. 

The pin configuration figures used in most of the figures, unless 
otherwise noted, are provided through the courtesy of Texas Instru- 
ments, Incorporated. The names Apple and Applesoft are trade- 
marks of Apple Computer, Inc., Cupertino, CA. The name TRS-80 
is a registered trademark of Radio Shack. 

We hope that you enjoy this book, and that it leads you to design 
and build some interface circuits of your own. 



Jonathan A. Titus, Christopher A. Trrus and David G. Larsen 
"The Blacksburg Group" 
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CHAPTER 



6502 Processor 



The Apple II® (Apple®) computer system by Apple Computer, 
Inc., uses the 6502-type of microprocessor integrated circuit. This 
"chip" forms the heart of the central processing unit (CPU) of the 
computer, the place where the actual mathematical, logical, decision- 
making, and other operations take place. The 6502-type microproces- 
sor chip is manufactured by MOS Technology (Norristown, PA 
19401), Rockwell International (Anaheim, CA 92803) and Synertek 
Corporation (Santa Clara, CA 95051). 

The 6502 is an 8-bit processor. Thus, all of the mathematical, logi- 
cal, data transfer, input and output operations operate on eight 
binary bits at a time. Each bit, of course, can be either a logic one 
or a logic zero. The 6502 uses an 8-bit data bus to transfer informa- 
tion between itself and various memory locations and input/ output 
(I/O) devices such as a keyboard, printer, etc. In cases where the 
value of the information exceeds the Umit of eight bits, multiples of 
8-bit data words are used. Each 8-bit data word is generally referred 
to as a byte. 

You should realize that the maximum value that can be expressed 
with eight bits is lllllllla or 255] y. If larger values are to be oper- 
ated on in an 8-bit computer system, then multibyte operations are 
required. Generally, this means that corresponding data bytes in two 
data words are operated on, followed by the operation being per- 
formed on the next corresponding set of bytes in the large data 
words. In this way large values, beyond the value of 255, may be 
readily processed. It is important to remember, though, that the 
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Apple CPU can only pjcDC^ mi transfesr eight bits or one byt^ £i a 
time. 

The 6502 uses a single set of eight pins to make 1^ €®nnection 
with the data hus in the computer. This data bus is used to transfer 
information both to and from the computer. This type of a bus is 
called bidirectional, since it allows information to flow in two 
ferent directions. This is much Mke a highway that is used to allow 
Viihiele^ to dl^ve one way in the morning and to allow vehicles to 
travel in the opposite direction in the evening. 

The 6502 generates control signals on the integrated circuit that 
ai% iQsed hem internally iutd esfternally ttt supi^se and manage i2ie 
flow of information on the bus, in one direction at a time. We wffll 
explore the generation and use of these signals later in this booL 



All computer systems have some memory associated with them. In 
general, the memory is used to store both a program that will control 
the operation of the computer, as well as the information that is to 
be processed. In the 6502 computer, each memory location can be 
used to store m^t bits of infoimatlon, ot one byte of data. Most 
Oft^M^^ cond^ of multiples of these one-byte storage locations, 
g<SS(iB4jIf in multiples of 1024, abbreviated IK. 

Hbe itilmory locations must be addressed in some way so that the 
compute Imows exactly where ft to store data or obtain program 
step information. The 6502 microprocessor chip has 16 address out- 
puts allowing it to specify any one of 2'® or 65,536 memory locations, 
eac^ of whMi em GmMn one fe^. fMs is fiteati ^h«H*e«ed t» 
indicating that 64K bytes of information can be addressed. In almost 
all microcomputer memory systems, each memory location is 
uniquely addressed with a 16-bit address. 

The address bus lines are labeled AO through A15, corresponding 
to the least-significant bit (LSB) through the most-significant bit 
(MSB), respectively. The LSB and MSB can both be either a logic 
atie or a logic zero, but their position gives the LSB a value of zero 
or one and the MSB a value of zero or 32,768. Since the 6502 is an 
8-bit processor, the address lines are frequently split into two groups 
of ei^t hnes each, A7-A0 and A15-A8. The Unes A7-A0 are referred 
to as the low or LO address, while lines A15-A8 are referred to as the 
high or III address. In many 6502-based computers, the HI address 
is also called the page address, since the memory may be arbitrarily 
di\^tied into tS6 pages, ^ bytes per page. "The uses of 'fee ad- 
dress bus will be explored further when software instructions are dis- 
cussed and when interface circuits are developed. Unlike the data 
bus, the address bos is unieSbedimtl^ tiie address information Mvm 
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The pin configuration of the 6502 is shown in Fig. 1-1, Altlbpu^ 
most (si oAer lA^g^ipmf im wmxAt^^^ pni ^f^m^ 
he able to identify 8 dftta bus ii^tit/oufput pins and the 16 
address output pins. 

ikoe the memory section & being (^bisetisHied, tbere are two 
types of memory devices used in microcomputer systems. They are; 

1. Read/ Wrife— Read /Write (R/W) memory is used for the stor- 
age of data that will be changed or updated. The computer 
must be able to place the information in a memory location and 
then be able to read it back. Programs that will change are also 
stored in R/W memory for the same reason. The lowest cost 
Apple computer contains 16,384 or 16K bytes of R/W memory. 

2. Heofi-On^— Read-only memory (ROM) is used when data val- 
ms and program steps Jtot lie alti»«d. T^ BASi€ ianer- 
prater program in your Apple system is contained in read-only 
memory chips. The Apple BASIC interpreter is stored in 12K 
of ROM. 

There are varioiQs sub-ek^sses e£ ^ese tfpes of naennory devices. 

The R/W memories may be either static or dynamic. Static memory 
chips will maintain the values stored in them until they are changed. 
Dynamic memories require refreshing by external h.a.rdimsee every 
few milliseconds or they will "forget" or lose the data stored in 
them. The R/W memories in the Apple are dynamic, with the neces- 
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sary refreshing circuitry contained on the computer printed-circuit 
board. 

There are many types of read-only memories. The various types 
are generally all static, the differences occurring in the means of stor- 
ing the 8-bit values in the memory locations. The two most important 
types are mask-programmed and field-programmed. The mask-pro- 
grammed devices have data values, program steps, etc., stored in 
them during the various manufacturing steps. They are generally re- 
ferred to as ROMs. The field-programmable devices require some 
kind of special programming circuitry to store the logic ones and 
zeros in the various locations. Some of the field programmable 
ROMs, or PROMs, as they are generally called, can be erased under 
high-intensity ultraviolet light. They can then be reprogrammed. 
This is very useful when programs are being developed that will be 
stored in read-only memory. It does not require the development of 
masks and chips— an expensive process— each time a program bug is 
found or a change is made. 

A few final words are required about semiconductor memory de- 
vices. The read-write devices are vohiiile^ since data (your program 
and values) will "evaporate" or disappear when power is removed 
from the system. The read-only memories, on the other hand, are 
considered to be nonvolatile, since they will maintain the data or 
program steps (the BASIC mterpreter) when the power has been 
removed. 

Most memory integrated-circuit packages or chips do not have all 
16 of the address lines connected to them. They have only enough 
address connections to uniquely address the memory locations within 
the individual chip. Thus, a 64-byte chip, small by standards of to- 
day, would only have 6 address line inputs while a 1024 ( IK ) byte 
memory chip would have 10 address line inputs. Memory chips such 
as these have an additional control or chip-enable input that allows 
banks or groups of the chips to be selected, one set at a time. Various 
decoding and selecting circuits may be used, thus allowing a 32K 
block of memory to be constructed from 64-byte or IK byte chips, 
or even combinations of the two. The main point here is that the 
memory chips do not require all 16 address lines to be connected 
directly to them, although some combination of all 16 address bits 
will be used to uniquely select one byte. You should not be confused 
when you are confronted with a IK X 4 bit memory that only has 
10 address inputs and a chip enable input. This concept will be de- 
veloped further as you study input/output data transfers. 

One control signal is generated by the 6502 processor chip to con- 
trol the flow of i nformation on the data hus. This signal is noted as 
READ/ WRITE, or more simply, R/W, Whenever a read, or a write, 
operation is to take place, the 6502 must specify a 16-bit address to 

IS 



locate the memory "cell" that is to be involved in the transfer. In this 
case, the cell is an 8-bit word or byte. 

The "bar" over part of the signal notation indicates that when the 
signal is a logic zero, a write operation is taking place; and when in 
the logic one state, a read operation is taking place. Thus, a single 
line controls all of the memory functions. In some 6502-based com- 
puter systems and peripherals, you may see the sig nal "spl it," t o pr o- 
vide two memory co ntrol sig nals , me mory read (MEMR or MR), 
and memory write (MEMW or MW). This takes some additional 
gating, so in most cases, the R/W signal is used by itself. It is avail- 
able at pin 34 on the 6502 microprocessor chip. 

You may also see the notation RAM used to incorrectly signify 
read/write memory. The acronym RAM stands for Tundom-access 
memory. In fact, all of the modern, easy-to-use memory devices are 
random access, since one may address one location and then any 
other, without having to sequence through all of the locations be- 
tween the two addresses. 

Pin configurations for typical memory chips have been provided 
in Fig. 1-2. 

For additional information about memory devices, we refer you to 

• Intel Memory Design Handbook, Intel Corporation, Santa 
Clara, CA 95051, 1975. 
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• The 808OA/908OA MOS Microprocmm Handbook^ Advan^gcl 
Micro Devices, Iik:„ Sunnyvale, GA 94086, 1977. 

• Mostek Memory Products Catalog, Mostek Corporation, Cat- 
rolltJjn, TX 75006, 1977. 

• Bipolar and CMOS Memory Data Book, Harris Semiconductor 
Prod. Div., Melbourne, FL 32901, 1978. 

Most mfcitcdn^titef -based sf stfeftw am l^^Sleist 
attached I/O devices. These devices may Standard peripherals, 
such as card readers, printers, displays, or may be sensors, con- 
trollers, and other devices fliattnost people do aot normdly associate 
with computers. The Apple is no exception. It already has several 
XiO devices associated with it: a television display, a cassette re- 
corder, and a keyboard. 

Other I/O devices can be added to your computer. These devices 
may be of your own design or they may be standard, commercially 
avafeMe a»dtes ft^ are con^atible with &e Apple. These If^ 
devices are mBribMfcf lfce individual memory locations that were dis- 
cussed in the pg^^ipili action. The I/O devices are attached to the 
data hm, ^im Is tratriferre^ te^ttettt and 1mm ^ma^ em&^tsy 
are also connected to the address bus so that ^bi^ 1m ^Ciiely 
addressed by the 6502 mic roprocess or chip, 

the flow of data to and from the I/O devices. This signal is also used 
in 6502-based computer systems to control the flovi' of information 
l# ttd from the mmtmf di^. *Efeis^ Iteg & »© difesentiation be- 
tween memory addresses and I/O device addresses in 6502-based 
computers. In computers that are based upon the 8085- or Z-80-type 
mlmjftfoe^sor ehips, there are different ■fedfcttiiqtiiss that are usfei to 
address memory and I/O devices independently. Since only one syn- 
chronizing signal is used to control memory and I/O devices, the 
Apple's 6502 processor will be eAer reading or writing at all times. 
When the R/W signal is a logic one, the 6502 is reading informatioji 
from the data bus. When the R/W signal is a logic zero, the 6502 is 
writing data to an external I/O device, or to a memory location. The 
"bar" over the W simply means that the write operation takes place 
when the R/W signal is a logic zero. You may see other signals with 
such bars over their names. Tli^ Mm|)ly ffly^s that the sigimls iatg 
active in the logic zero state. 

Since we will be concentrating on the use of I/O devices with the 
Apple, we have IdEt a great deal erf the spm^Q i^ammskm to re- 
maining sections. 
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Review 

At this point, you should understand that the 6502 transfers and 
operates on eight bits of data at a time. Complex calculations and 
operations often require multiple groups of eight bits or bytes. The 
bytes are transferred to and from the 6502 CPU on an 8-bit bus, 



Table 1-1. Control Signals Used for Interfacing 



DATA BUS 


D7-D0 


An 8-bit bidirectional set of lines for transfer of 
information between the CPU and l/O devices. 


ADDRESS BUS 


A15-A0 
A15-A8 
A7-A0 


A 16-bit unidirectional address bus used to ad- 
dress both memory and l/O devices. 
HI address bus, most-significant eight address 
bits. 

LO address bus, leasf-significant eight address 
bits. 


CONTROL SIGNAL 


R/W 


Read/write control signal. 



NOTES: The "bar" notation, i.e., W, indicates a logic zero is the "active" state, the state that 
causes ihe corresponding action 1o take place. 

In each case in which a signal is enumerated, the numbers increase as the significance of the 
bits increases, i.e., A15 = most-significant address bit (MSB). 



The 6502 uses a 16-bit address bus to address individual memory 
location and I/O devices. The address bus is frequently broken into 
a HI and LO address bus, of eight bits each. The single control sig- 
nal, R/W, controls the flow of information to and from the 6502 CPU. 
The signals and their designations are noted in Table 1-1. 

SOFTWARE I/O CONTROL INSTRUCTIONS 
I/O Commands 

The Apple computer has a number of instructions that are used to 
control I/O devices. For the most part, though, these instructions are 
used to control specific I/O devices or to perform specific functions. 
Without realizing it, you are already familiar with some, if not all, 
of these I/O instructions. 

Here are some specific examples of these I/O control instructions, 
to refresh your memory. 

The INPUT and PRINT commands are probably familiar to you. 
The INPUT command causes a BASIC program to stop and wait for 
an input from the keyboard. The PRINT command causes an answer 
or string of characters to be "printed" on the tv screen. 

Example 1-1. A Simple i/O Program 

10 INPUT "VALUE OF X IS"; X 

20 PRINT " INPUT VALUE WAS"; X 
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If you executed the program in Example 1-1, the value associated 
with the variable, X, would have to be entered into the computer 
before the program passed control to statement 20. These two types 
of I/O statements are frequently used to allow an operator to enter 
a value and to see it displayed. There are many variations of both the 
INPUT and PRINT commands, but these two examples serve to il- 
lustrate the point; you have already been using I/O operations in 
BASIC-language programs without difficulty. 

You may have already discovered that there are also graphic dis- 
play I/O commands in BASIC, too. These are commands such as 
HOME, PLOT X,Y and SCRN (X,Y). The HOME command clears 
the screen, and places the blinking cursor at the "home" position in 
the upper left-hand corner of the tv screen. The PLOT and SCRN 
commands require the use of "coordinates" to indicate where an 
operation is to take place. 

The program in Example 1-2 shows how some simple graphic dis- 
play commands are used in a short program. This program generates 
a display of randomly changing colored dots on the tv screen. If you 
are using a black-and-white (b/w) tv, you will see the dots in vary- 
ing shades of gray. 

Exampla 1-2. A Random Color Pattern Genvratar Uting l/O Contmands 

10 GR 

20 X = INT(40*RND{1)) + 1 
30 Y=INT(40 + RND(1)) + 1 
40 COLOR=INT{15*RND(l)) + 1 
50 PLOT X,Y 
60 GOTO 20 

There are two other commands that you may not have considered 
to be I/O commands. These are the LOAD and SAVE commands 
that are used to read and store programs on cassette tapes. Each 
command causes a preset series of operations to take place, control- 
ling the cassette recorder. The use of these commands is fairly obvi- 
ous, so we will not provide an example. 

Other I/O commands are the IN#X and PR#X operations that are 
associated wdth special I/O devices that can be substituted for the 
keyboard and tv display. It is important that you realize that these 
I/O instructions are specific to the Apple computer and its BASIC- 
language interpreter program. These instructions would be mean- 
ingless to other 6502-based computer systems, unless they used the 
Apple BASIC program. The instructions are also specific to one I/O 
device, i.e., the HOME command will not have an effect on the cas- 
sette recorder, or any other I/O device. Likewise, the INPUT com- 
mand controls the input of values only from the keyboard on the 
console. 



General-Purpose I/O Commartds 

Although there are some general-purpose I/O commands in the 
INTEGER BASIC interpreter program for the Apple computer, for 
this book we have chosen to use what we consider to be the more 
flexible APPLESOFT BASIC interpreter program. If you wish to 
convert your Apple computer to this program, a local Apple com- 
puter dealer can assist you. 

The two I/O device commands are PEEK and POKE. They are 
used to transfer data to an external device from the computer 
(POKE), and to the computer from an external device (PEEK). 
There is a specific format for these instructions that must be used if 
the instructions are to operate properly. 

Input and output devices will be referred to as ports. Thus, an out- 
put device will be an output port and an input device will be an in- 
put port. This is standard nomenclature used throughout the micro- 
computer industry. 

The output instruction, POKE, must specify the address of the 
I/O device that is to be involved in the transfer of data and also the 
value that is to be transferred to the addressed device. The actual 
format for the POKE instruction is POKE, x,y, where the x value 
represents the decimal address of the output device that is to receive 
the data value, y. The data, y, must also be a decimal number. Since 
the 6502 microprocessor chip can address 65536 memory locations, 
the address must be within the range of to 65535, inclusive. The 
data value must be within the range of to 255, inclusive, since the 
computer uses an 8-bit data bus for all data transfers, and the largest 
number that can be transferred on such a bus is 255, 

The value 215 is sent to output port 12684 in the following state- 
ment; POKE 12684,215. 

The input instruction, PEEK, is similar to the POKE instruction, 
except that no data value is incorporated into the command. We are 
interested in determining the value present at the specific input de- 
vice, so only the decimal address of the input device is specified; 
PEEK (x), where x is the decimal address of the input device. 

It does little good to input a value without doing something with 
it, so the input command is always incorporated in a complete state- 
ment, rather than being a statement by itself. An example of this is 
Q=PEEK( 34579). 

In this case, the variable, Q, is assigned the decimal value that has 
been input from device 34579. It is important that you remember to 
enclose the address of the input device in parentheses. 

Whenever a PEEK command is used, the value that is input will be 
between and 255, inclusive. Again, this is due to the limitation of 
8-bit transfers. 
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Table T-2. Valid Input (PEEK) and Output (POKE) Command Structures 



POKE 45124,98 


L = PEEK (23109) 


POKE N,120 


L = PEEK (Q) 


POKE 4S124,X 




POKE X,M 





The input and output commands may have variables specified 
within them, rather than specific values for port addresses, and in the 
case of the POKE command, data values. Thus, all of the PEEK and 
POKE commands shown in Table 1-2 are valid. We have assumed, 
of course, that the values for the variables, N, M, X and Q have been 
specified somewhere in the program prior to the use of the instruc- 
tions shown in Table 1-2. 

Input and output commands in which the address values exceed 
65535 will generate an ILLEGAL QUANTITY ERROR in the Apple 
computer. An attempt to output a numerical data value that exceeds 
255 will also generate an ILLEGAL QUANTITY ERROR. 

We have provided some examples that show the use of the POKE 
and PEEK commands. While the programs shown in Example 1-3 
can be executed, they will not do anything useful, since you do not 
have any external I/O ports connected to your computer, at present. 

Example 1-3. Simple I/O Programs for PEEK and POKE Commands 

10 INPUT "OUTPUT PORT # =";P 

20 INPUT "VALUE FOR OUTPUT"; V 

30 POKE P,V 

40 GOTO 10 



10 INPUT "INPUT PORT # = "; M 

20 PRINT "VALUE AT PORT PEEK (M} 

30 GOTO 10 

Since 6502-based computers cannot distinguish between memory 
locations that are used for the temporary storage of programs and 
data, and those that are being used for I/O ports, the PEEK and 
POKE instructions are frequently used to examine and alter the con- 
tents of various memory locations within the Apple. If you POKE 
information into read/ write memory in an indiscriminate fashion, 
you may "write over" important parts of your program, or informa- 
tion that has been temporarily stored by the RASIC interpreter. The 
net effect is a "crash" of the computer system, in which your program 
and data will be lost or significantly altered. It is probably not a good 
idea to randomly POKE information into various addresses, until 
some specific guidelines are provided. Of course, you can use the 
PEEK command to examine the contents of a memory location 
whenever you wish, since this command will not alter the contents 
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of an examined memory location. From the previous discussion of 
oaemory devices, you should realize that the POKE operation wCtt 
have no effect on tfae jmA<3iBly memory deuces in the Apple. 

Mmiiery Ma|» 

At this point it is a good idea to take a look at the "maps" of the 
memoiy addresses that are used by the Apple, A complete 64K mem- 
ory nmp is shown hi 5%. 1^. For flie sake of convenience, the mem- 
ory addresses are provided in both decimal (base-10) and hexadeci- 
mal (base-16) notation. The hexadecimal numbers have a sufiBx of 
TH" to distinguish &i&eti fttm #i& dedmal nwmt»<a*. 

The memory space for the Apple computer has been divided into 
four 16K blocks. Three of the blocks have been as.signed for R/W 
memory, and tm^Jtp^tm computers ime fise R/W #1 block "filled" 
with read/write memory chips. The remaining R/W blocks may be 
used for futinre expansion of R/W memory, if this is required fur par- 
tlcalar applications. In most cases, we have found fisat 16K of R/W 
memory is sufficient Add-on memory chip kits are available from 
many suppliers, and most Apple users can probably add the addi- 
tional memory chips to their system without much difficulty. 

The remaining 16K block of memory has been set asude for both 
ROM a«d I/O port addressing. The system ROMs for the Apple, 
which include the BASIC interpreter and the monitor programs, take 
up 12K of this space. The remaining 4K space is divided into two 2K 
spaces fet I/O addtreasing and future expansfott of the Apple. The 
I/O block with addresses COOOH to C7FFH, inclusive, is the one 
of major importance for interfacing, since it has been specifically set 
iifeif purpose and it wHl never he used in Apple computer 
systems for any other purpose. Some of the addresses within this 2K 
block have been used by the Apple for controlling things such as the 
sfieaker, the k^hourd, and the eassetlae mawdmi. The actaal adchess 






mm 










16K 


mn 


163S3 


3FFFH 






li3M 


4O0OH 










16K 


m»i 


32767 


7FFFH 






mf» 


8000H 










ISK 


mn 


mu 


BFITH 






&m 


t^H 








16K 




mm 


FFFFH 
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51199 C7FFH 




y^mm C800H 




53Z47 CFFFH 




5IZ4I DOgOH 


m 


SYSTEM ROMS 




fiSK FFFFH 
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assignments are shown in Table 1-3, We refer you to Basic Program- 
ming Reference Manual, and Apple II Reference Manual, for details 
on the actual use of these I/O addresses. These manuals are provided 
with the Apple II computer, and are also available from Apple Com- 
puter, Inc., 10260 Bandley Dr., Cupertino, CA 95014. 

The remaining 2K block of memory, C800H-CFFFH, has been set 
aside for future expansion. You may use this space for additional 
read-only memory, if you have long programs that you wish to have 
readily available. 



Table 1-3. Apple I/O Addresses and Their Uses 



Function 


Address 


Decimal* 


Hexadecimal 


Keyboard data 


49152 


cooo 


Clear^keyboard strobe 


49168 


COlO 


Speaker 


49200 


C030 


Cassette Output 


49184 


C020 


Cassette Input 


49256 


C060 


Flag Inputs 


49249-49251 


C061-C063 


Analog Inputs 


49252-49255 


C064-C057 


Analog Clear 


49264 


C070 


Utility Strobe 


49216 


C040 



''Only positive addresses given. To calculate negative addresses, just add — 65536 to the deci- 
mal addresses provided. 



In later sections of this book, the actual use of the I/O addresses 
will be described in detail. At this point, it is sufficient that you un- 
derstand that a specific set of memory addresses has been .set aside 
for your particular applications. You should also realize that the 
memory map shown in Fig, 1-3 is particular to the Apple computer. 
Other 6502-based computers will probably have different memory 
maps, with R/W memory, read-only memory, and I/O device ad- 
dresses located in different areas of the map. 

Software Commands and Interface Circuits 

As you are probably aware by now, the PEEK and POKE instruc- 
tions each cause some actions to take place, either at I/O devices or 
at memory locations, as a direct result of the use of the instruction. 
Instructions such as A=1.339 will cause some values to be stored in 
memoiy, but we do not know what memory locations the Apple has 
assigned to the variable "A" and we do not know how the value 1.359 
has been stored. The PEEK and POKE instructions each cause a 
definite, known sequence of operations to take place, transferring 
data bytes, generating control signals, and transferring address in- 
formation on the address-bus lines. These definite and reproducible 
actions allow us to u.se these commands to control I/O devices. We 
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will now explore the actions that each of these software commands 
causes to take place. 

The PEEK and POKE instructions operate in a very similar man- 
ner. In each, an address is specified, requiring 16 bits of informa- 
tion. During the execution of either instruction, the address informa- 
tion contained within the command is transferred to external devices 
on the address-bus lines, A15-A0. In this way, the I/O device address 
is available to all of the devices and circuits that are connected to 
these address lines, both memory and I/O devices. 

When a POKE instruction is used in a program, the data value is 
also output by the 6502 chip, but on the data-bus lines, D7-D0. Once 
the data bits and the address bits are "stable" or present on their re_- 
spective buses in useable form, the 6502 asserts the READ/WRITE 
signal on the control bus. This synchronizes the acquisition of the 
data by the I/O device that was addressed. Of course, external cir- 
cuitry is required to "capture" the data, as well as to identify the se- 
lected I/O device and synchronize it with the 6502-based system. A 
timing diagram for these signals, as they appear on the 6502 system, 
in this case the Apple, is shown in Fig. 1-4. Of course, the POKE 
command involves many assembly-language instructions, and the 
timing diagram shows what happens only during the time of the 
actual data transfer. At this point, we are only concerned with what 
the 6502 does during a POKE operation. 

When a PEEK instruction is executed, the data is not contained in 
the instruction, but is acquired from an external I/O device. Only 
the address is specified. The 16-bit address is placed on the address - 
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Fig. 1-4. Write operation signal relationships. (See Appendix C.) 
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bus lines when the PEEK instruction is executed. When the address 
information is present, the corresponding I/O device must place its 
data on- the data bus so that it may be accepted by the 6502 proces- 
sor. During a read operation, the R/W signal from the 6502 is a logic 
one. Additional circuitry is required here, too, to select the I/O de- 
vice and to gate its data onto the data bus. A typical timing diagram 
for the PEEK command is shown in Fig. 1-5. 

TcYC 




DATA FROM 
MEMORY 



Fig. 1-5. Read operation signal relationships. (See Appendix C.) 

We will describe shortly some of the circuits that are used for in- 
put and output ports. You have probably realized that while we have 
described an II O port as one that can either receive data that is out- 
put by the microcomputer or transmit data that is input by the micro- 
computer, some Ij O devices may actually contain a number of indi- 
vidual I/O ports. Industrial controllers, data .storage devices (disks, 
cassettes), analog converters, and other I/O devices may have a 
number of I/O ports, since they may require more than eight bits of 
information from the computer and they may also need to transfer 
more than eight bit.s of information to the computer. In any case, 
transfers of data that contain more than eight bits always involve 
the transfer of multiple bytes to and from the computer and the in- 
dividual 8-bit I/O ports. This is important to remember; information 
is always transferred eight bits at a time. 

Software Command— Data Transfer and Control 

In most cases, the PEEK and POKE commands will be used to 
transfer 8-bit data values between the I/O devices or memory loca- 
tions and the 6502 computer. As we noted previously, some data 
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transfers will require more than eight bits of information, so multi- 
ple bytes are transferred, one byte at a time. 

There are also cases in which the actual value of the data trans- 
ferred is meaningless. The bits may be iised to represent individual 
two-state conditions that are unrelated to the positional values of 
the bits. For example, a number of sensors could be connected to the 
Apple indicating conditions such as tank empty-or-fuU, heater on-or- 
ofiF, value open-or-closed, and so on. A PEEK command could be 
used to input the status of these indicator bits, through an 8-bit input 
port. Thus, the value read from this input port might be 100, but the 
port is sensing eight individual on or off (logic one or logic zero) 
states, so the value of lOOio is meaningless. The individual binary 
bits each represent the state of an individual sensor. In this case; 

lOOio = OIIOOIOO2 

This indicates that three of the sensors are in the logic one state and 
five are in the logic zero state. 

The POKE and PEEK commands can also be used in a similar 
manner to turn a device on or to turn a device off, based upon the 
state of the individual bits that have been sensed elsewhere in a con- 
trol program. In fact, many of the I/O addresses used by the Apple 
are assigned to simple on/ off devices such as the speaker. Thus, a 
simple command: 

A = PEEK(49200) 

will generate a "blip" on the speaker in the Apple. You should under- 
stand that the variable, A, is a "dummy," and its final value is not im- 
portant, since the net eflFect of the simple BASIC statement is to 
pulse the speaker once. The speaker control command may be used 
in a loop to generate a low buzz from the speaker. This is shown in 
Example 1-4. 

Exampl« 1-4. A Simple Speaker Control Program 

10 A = PEEK(49200) 
20 GOTO 10 

The important point to remember here is that the PEEK and 
POKE instructions are not limited simply to controlling the transfer 
of information on the data bus. They may also be used for specific 
control functions, such as pulsing a counter, turning on a pump, or 
tilting a solar collector. 

Assembly Language and BASIC 

The BASIC-language programs that you write on your Apple com- 
puter bear very little relationship to the actual instructions that the 
6502 microprocessor chip can actually execute. Each of your BASIC 



Ste^&mmats and commands Is ^ei$^^^f^efi§ iSm BASIC ia^rpre^ 
resident within the Apple compli^v A programming maniml for the 
6502 chip, itself, would bear little relationship to the Apple software 
manual. The commands are very different. 

The 6502 does not have a PWNT conunand, so it would not per- 
form the following operation: 

PRINT "THIS LOOKS LIKE FUN" 

Hie BASfG interpreter determines that a PRINT qpeiation is to lake 
place and it then executes a series of assenibly language program in- 
structions that actually place the codes for t he alpha&^ieal charae- 
Ite |» Ihs ^lay ffleffiffly to spe31 out, "miS LCMSKS LIKE FCTN." 
The 8l®€fBfjbly language steps consist of logic ones and zeros that 
cause flie necessary internal and external 6502 operations to take 
pla^ to transfer Ae mei^age pwtton of the PHINT Qetnmaiid fo^^iie 
display memory. 

While we will not use assembly language programming to any ex- 
tent in this bodk, ftm should be awai© that it is the "base* computer 

language that causes the Apple to operate the way that it does. 

The PEEK and POKE commands each cause many, many assem- 
bly language commands to be executed t& "p^BsGB fee ivv'eaiffl i^e^ 
of data transfer. Since these BASIC language instructions must be 
interpreted, even when used one right after another, or in a loop, the 
interpretation software process can be slow. Two programs are 
shovm in Ejcample 1-5, both of which control the speaker in the 
Apple. Each series of program steps does the same thing; generating 
a tone on the speaker. Simply by listening to the differences in the 
two tones prgduced, ^ou will be able to appreciate the difference in 
the speeds^ t^^E&m rflbese programs, 

Ininph C«n|iariiwn tijkmml^ tmsiniii and MSIC hrogrMM tof Sfmhtttlmimi 
Basic Prognm Asssmbly Languag* 

10 A = PEEK(492jW!) GO LDY #$C0 

20 QOIO TO LOOP IDA #$0C 

JSR WAIT 
IDA SPKIt 
DEY 

BNE LOOP 
JMP GO 

The assembly language program generates a pleasing, even tone, 
while the BASIC program generates a low rumble. The assembly lan- 
jBrige program is similar to the one used b^ die Aj^U Mm^hSS ftt^ 
^m wkexe the internal WAIT subroutine has been med to ^mestsM 
a delay. 

In some cases, assembly language pfflgrams have a five-hundr04 
*o one advantage over BASIC programs, although the BASIC pitt- 
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grams are probably easier to write and debug. Assembly languag0 
pjgpiatftMftg Is §§im^^ Itifll we^o^frtrntettded for flte nov^ee. 

We will be mentioning assembly language programming very lit- 
tle, concentrating on the use of BASIC language programming in- 
sb^d, Fdt furftier information on i^l^ assembly langEia^ pro^Rftm- 
ming, we recommend 6502 Software Design and Frogramming and 
Interfacing the 6502, With Experiments ( Howard W, Sams & Co., 
Im^^ ladiaiiaptej IN 46268} . 

fitnaiy anil Oecimail NumlMSifng 

"Mie Apple computer system acquires, processes, and prints 6sm- 
mal (base-10) numbers. This makes ft csorijpatible witibi €be number- 
ing used by most people today. It WOflld be difficult fot Us to readily 
understand and convert data values that were printed in a nondeci- 
mal format. The data and address lines are directly connected to the 
inicroprocessor chip, so they are binary, having only two states— 
a logic one or a logic zero. Thus, when we specify an I/O port ad- 
dress in a PEEK or POKE command, we must realize tihat the ad- 
dress (0^65^) np^t itt its biliary form on ^iSsess 
(OOOOOOOOOOOOOOOO-llllllllllllllll). You should be able to mak^ 
the conversion between decimal and binary, in either direction. 

Mfee^^^v &e isrta 'imTties "teirfeaEfed ite find from &m compiate 
by the PEEK and POKE commands are also specified or acquired as 
8-bit binary values, since the data bus is only eight bits "wide," The 
8-bit data bus is a function of the data processing cap^Hlily within 
the 6502 chip. It is not a function of the Apple. Thus, we are limited 
to 8-bit data transfers. Is this a great limitation? Generally not. In 
^ite of it, the Apple can process a great deal of informaMMj aM|> as 
you will see later, it is easy to interface to I/O devices. 

One final note on addresses is necessary before leaving this chap- 
tesTi The BASIC interpreter in the Apple computer has been set iip 
to handle both negative and pp0ive addresses.Tliis does ijot meait 
tiiat there are actually negative isddresses in the computer. Can you 
imagine negative street numbers? The negative numbers are simple 
due to the way in which the binary equivalents of the addresses are 
mt&i M ipffo. *ftti$; iar the spefe, 

equivalent to —16336. To avoid confusion, we strongly recommend 
the use of the positive addresses. You can easily convert between 
«#f*(«^ atid pesitiif© addresses simply by (s) ii^lig t^BI titf a 
negative address to yield the positive equivalent, or ( b ) by subtract- 
ing 65336 from the positive address to yield the negative equivalent. 
Bffl^ addresses, amd — 16^39, j|eaemti €te saaii If^W iiiliili, 
but we think that you will agree tfett m^tfw adi&^es Mr sfiwafls a 
bit abstract and confusing. 
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Apple Interfacing 



At this point, you are probably wondering: 

• How does the Apple actually transfer information to I/O de- 
vices? 

• How are the I/O devices actually synchronized to the operation 
of the computer? 

• How are individual I/O devices selected or identified? 

• How do I/O devices place their data on the data bus and how 
do they actually receive it from the data bus? 

These are important questions, since the answers to them will pro- 
vide the basis for your understanding of microcomputer interfacing. 
We will be answering these questions in this and other chapters. We 
will also provide some experiments that will reinforce the concepts 
through hands-on experience. 

A few examples of digital circuits will be provided in this chapter. 
We have assumed that you can "read" and interpret a logic circuit 
diagram, and that you are familiar with the more common SN7400- 
series transistor-transistor logic (TTL) circuits 

t/O OEVrCE ADDRESS DECODING 

Before we can discuss the actual transfer of information between 
I/O devices and the computer, we must first understand the circuitry 
and the signals that are used to identify or address the individual 
I/O devices. There are many schemes that may be used and we will 
examine several of them. It is impossible to show every possible 
scheme for addressing I/O devices, since modifications will be made 
to suit special needs. 
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when the Apple computer is programmed to perform a data trans- 
fer using either of the general-purpose I/O commands, PEEK or 
POKE, certain signals are generated by the 6502 processor to syn- 
chronize the flow of data. At this point, our main concern is the use 
of the address bus lines. These are the 16 lines that address individ- 
ual memory locations and I/O devices. You should recall that the 
PEEK and POKE instructions each contain decimal address infor- 
mation that is used to identify the addressed memory location or I/O 
device. Of course, the Apple computer has no way of distinguishing 
between a memory location and an I/O port, 

DEVICE ADDRESSING 

Each I/O device that is to be used with the computer must be able 
to recognize its own device address. Since the PEEK and POKE 
commands use 16-bit addresses, each I/O device must monitor these 
16 address lines, A15-A0, for the occurrence of its address. There are 
three basic schemes that may be used by I/O device circuits to ac- 
complish the monitoring for a specific address. These are: 

• Gttfing-detecting a specific combination of logic signals. 

• Decoding-a more flexible gating scheme in which many ad- 
dresses may be detected. 

• Compcring-comparing a preset or known address with the ad- 
dress-bus signals until a match occurs. 

Combinations of these three techniques are possible and there are 
probably many variations that are possible. We will describe exam- 
ples of each of the three basic address decoding schemes. 

Using Gates for Address Decoding 

In the scheme for decoding device addresses in which individual 
gates are used, the address must be known so that the gates can be 
properly configured. In this example, we will use the device address 
lOlOlOOOllllOUl:; or 43255,0- Since the binary notation is long, and 
somewhat cumbersome, you might feel more comfortable with the 
hexadecimal equivalent, A8F7H. Since nand/and gates are the pre- 
dominant type of gating logic available, we will use these types of 
circuits in our logic. 

To refresh your memory, the pin configurations for several types 
of and/nand gates are shown in Fig. 2-1, with the generalized truth 
table for a two-input and gate and an equivalent nand gate shown 
in Table 2-1. Since inverters such as the SN7404 are often found in 
device addressing circuits, a pin configuration for this chip has been 
included in Fig. 2-1. The truth tables in Table 2-1 also show the func- 
tion of an inverter. In aU cases, the logic one state is the higher volt- 
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age ( +2,5 to +5 uofes ) ami ifte logic zero state is the lower voltage 
( 0.0 to 0.8 voU ) . The nand gate functions are available with 2, 3, 4, 
8, and 13 inputs, wfaile tlte ahd gatm ioe available with <x 4 
inputs. 

Since the unique output state, logic one for an and gate and logic 
zero for a nand gate, occurs only when aU of the inputs to an and or 
a KANQ j^te are all logic ones, we will have to configure the binary 
addles MOlOGiOllllOlll^ so that it g^«»aeed 16 logic ones at die 
input to the and or nand gate, when it is present on the 16-bit ad- 
dress bus. You have probably reahzed that there are no IS^inpuct and 
m ^mm giAes avRfiable commeteaB^tf, so some t^&er eonfigumSbn 
must be used instead. It is very easy to use a separate 8-input nand 
gate to detect a pattern of binary address bits on the high-address 
bus ( A15- A8 ) , and another 8-input nand gate to detect a pattern fli 
binary bits on the low-address bus (A7-A0}. Simple inverter funey 



Tobie 2-1. Truth Tables for a Two-Input AND Gate, 
NAND Gate and an Inverter 
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tions are used to invert the logic zero address bits so that they apply 
logic ones to their corresponding gate inputs, as shown in Fig. 2-2. 
In this circuit, two inverters and a nand gate have been used to com- 
bine the output from each of the 8-input nand gates, so that the out- 
put of the circuit will be a logic zero only when the complete pattern 
of 16 bits, 101010001 IIIOIII2, is detected on the 16-bit address bus. 

A15 1 

A14 [>o— 

A13 1 

AlZ [>o 

All 0> 

AlO [>C3 

A9 [>v 

Ag 1>° 



A7 1 

A6 1 

A5 1 

A4 1 

A3 [>> 

A2 1 

Al 1 

AO 1 

Fig. 2-2. Gating circuit used to decade address 43255 or ASF7H. 

One of the disadvantages of this circuit is that some of the address 
signals must go through four gates before reaching the decoded ad- 
dress output from the 2-input nand gate. Since each gate delays the 
signal slightly, this might cause some timing problems in the circuit. 
Actually, the time delays are fairly minor, and we will ignore them 
for now. The delay can be reduced somewhat by using a nor or or 
gate in the circuit to combine the outputs from the two 8-input nand 
gates. This is good design practice, nor and or gates are readily 
available and are used quite extensively in computer interfacing. A 
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Fig. 2-3. Typical NOR and OR gat* IC pin configurations. 

typical NOR and or gate are shown in Fig. 2-3, with the correspond- 
ing truth tables provided in Table 2-2. 

While the gating scheme shown in Fig. 2-2 is effective in decoding 
a single address, and relatively inexpensive, it is inflexible. A more 
flexible approach is shown in Fig. 2-4. This circuit illustrates the use 
of a gating scheme in which inverters may be used to invert individ- 
ual address bits, as required. The bits may also be used without in- 
version. The jumpers allow the device address to be preset, as illus- 
trated in Fig. 2-5, In this circuit, only the low-address bus gating has 
been shown, for clarity, A duplicate gating circuit is required for the 
high-address bus lines. In this type of a gating circuit, any one of the 
65536 possible addresses may be selected, but only one at a time. 

The programmable gating circuit provides broad flexibility, in 
that addresses are easily changed to meet specific requirements for 
an interface, but such a circuit can select only a single address, and 
this is a severe limitation. When several I/O devices are located on 
the same circuit board, each will require its own address gating cir- 
cuit. This limitation can be overcome with other addressing schemes. 

Unfortunately, the gating schemes that we have shown are not all 
that is required to uniquely address and control an I/O dev ice. You 
should recall from the discussion of the_ READ/ WRITE (R/W) 
signal in the previous chapter, that the R/W signal is used to synchro- 
nize the flow of information to and from the computer. The I/O de- 
vices must also use this control signal, if they are to use the data bus 
properly. In many interfaces that are designed for 6502-based com- 



Table 2-2. Truth Tables for a Two-Input NOR Gate and OR Gate 
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puter systems, the R/W line is used to provide the logic-zero write 
pulse, with the R/W signal being inverted to generate a se parate 
w^d p ulse. The two resulting control signals, WRITE (WR) and 
READ ( TfD ) , are easy tb tise in interface circuits, since they are ac- 
tive in the logic zero state. The use of these signals is shown in Fig. 
2-6. In this c ir cuity the o utput from the 16-bit gating circuit is qom- 
Mtt^sS wftlt I© ffiddlW to piovtde tm isipafet foie I/O pest eoiittt*!. 

These t wo contro l signals are a ewnbination of the decoded address 
and the WRIT E pul^e, and a combination of the decoded address 
miA tibe READ pc^^. Tlie resultiag p^m ^ssm pt& ls daHed m 
address select puhe, or a device ^eleiSl/pi^e. More gene rally, a de- 
coded address is gated with a functi&(k $gfye (RD or WR) to gener- 
ate a devic e select pulse. In the cB^t^gi»in aihtii^ lii Fig. 2-6, the 
RD 49280 pulse could be used to control an input port, while the 
WR 49280 pulse could be used to control an output port. Note that 
the noteticBi f »r tbe WR ^^Xi pul^ does oot have a "hax" mm it 
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FROM HIGH ADDRESS GATE 




Fig, 2-6. Using RD and WR signals to ganarate device select pulses f«r 
device synchronization. 



This mean s that the pulse is active in the logic one state, while the 
RD 49280 pulse is active in the logic zero state. In this example, it is 
quite proper to note the ad dress on the I/O ports by using a hexa- 
decimal value, for example, RD C080H. 

Before going further, you should be sure that you understand that 
a reading operation involves reading information into the computer 
from an input port, while a writing operation involves the transfer of 
information from the computer to an erternal device. It is also quite 
proper and useful to use one add ress to control an input port and an 
output port. Since the RD and WR pulses cannot be coincident, 
there is no conflict between an input port and an output port that 
have been assigned the same address. You cannot assign two input 
ports the same address, and you should not assign two output ports 
the same address. In fact, you may find that even though an input 
port and an output port have been assigned the same address, they 
may be unrelated as to their function, and may be used on separate 
interface circuits. 

The concepts and the basic circuits that have been developed in 
this section are very important and they will be carried forward to 
other sections and chapters. It is important that you understand the 
use of the signals that have been discussed to select devices. We have 
not yet discussed what these input and output devices are, or how 
they work, but we shall discuss this in the next chapter. 
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Using Decoders 

In many cases, it is easier to use ^kc^mhr circuits in pls^ mi the 
gates address detecting circuits, and, in some cases, in place of the 
KCna^gate device select circuits, too. Why are decoders so useful? 
l^&^^e^ ft is beist to tftM a l&tA: at severtd tfp^ of decode m me 
what they look like and how they operate. As you examine the de- 
(Soder circuits, keep in mind that they are simply collections of gates 
hiVe been "inte^ted" into an easy-to-use deeibcE^r circuit. 

D«:oder circuits are generally specified as x-line to y-line decod- 
ers, where x represents the number of binary inputs, say four inputs, 
and where y represefite#e imieib^ ^possible outputs, or the num- 
ber of different binary states present on the x inputs. Thus, for the 
four inputs, there would be 16 possible outputs, creating a 4-line to 
16-line decoder or a 4- to 16-Iine decider. This iHj in fad^ a real de- 
coder circuit, as you will see. 

Each of the binary inputs has two states, a logic one and a logic 
zero. These inputs are independent of one another. The outputs are 
idsffl Irinary^ in fbe sense that they have two possible values, but th^ 
m^ n^iii^hpmdeta. Thistie will otitf be one unique output from the 
d&eia§Sff representing the value or "weight" present at the binary in- 
puts jici ttost cases, the unique output state is a logic zero, with the 
odiet- outputs! in tlUitr logic! mm Stette. 

A typical decoder integrated circuit is the SN74LS139. This inte- 
grated circuit actually contains two independent two-line to four- 
line de^odei^, as Amm U Fig- 2-7. 

The truth table fof |Ne ;SN74LS139 is shovm in Table 2-3. 

Of course, the tn^ table applies to both of the decoders within 
%$/!^¥tMMM M^ileated-circuit ^i^bige, or "chip." Most decoder 
drc^ts fi3«Jt»J>0mlte m emblwg lBt|»ti^, so that the decoder may be 
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Table 1-^. Truth Tabte for on SN74LS139 Decoder 
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turned on or turned off by one logic input. This is the function of the 
ENABLE or "G" input on each of the decoders in the SN74LS139. 
Note that when the "G" input is a logic one, all of the outputs are 
forced into the logic one state, regardless of the states of the A and 
B inputs. This allows the decoder to be gated on or off. In the off 
state, the power is not removed, but the outputs are all forced into 
the logic one state. 

Let us now examine a simple, rather trivial, example of the use of 
a two-line to four-line decoder for device address decoding. We will 
assume that we only have a few I/O devices, so that the decoders in 
the SN74LS139 decoder package can handle our needs. A typical 
decoder circuit is shown in Fig. 2-8. In this circuit, only two address 
bits have been decoded, the rest have been ignored. Note that the 
enable input has been grounded so that the outputs of the decoder 
will operate properly. The added nor and ok gates generate the 
actual device select pulses. 

The device select signals have been noted as RD X, RD Y, and WR 
Y, since there is no specific address that will actuate each. Addresses 
01010101 00000010, 00011101 lllIOllO and 00000000 11111110 will 
all cause the RD X device select pulse to be generated, if they are 
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Fig. 2-B. 2-Line-to-4-line decoder used for device addresiing. 
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used in PEEK commands, for example A=PEEK( 21762). This non- 
absolute device addressing results because address bits A15-A2 have 
not been used in the decoding scheme. Nonabsolute addressing 
means that there are several addresses that will actuate the selected 
device. The circuit shown in Fig. 2-8 will decode four addresses and 
thus eight individual devices may be selected, four input de\'ices 
and four output devices; additional nor gates or OB gates are re- 
quired, though. In a small system, this may be adequate, although 
the decoding scheme does not provide a great deal of flexibility in 
allowing the addition of new I/O devices beyond the original eight. 
Although this scheme is not very flexible, let's take a closer look at 
it, since it allows us to develop two other concepts that can be ap- 
plied to other decoder schemes. 

In Fig. 2-8, the enable input, "G," of the decoder is simply 
grounded, to always enable the decoding action. This input can allow 
the decoder to be used for absolute decoding. A gating circuit can be 
used to supply an enabling signal to the decoder only when a preset 
pattern of address bits, on address lines A15-A2, is present. You have 
already seen the use of multiple -input gating circuits; the circuit in 
Fig, 2-5 is a good example. This circuit can be readily adapted to 
provide the enable input for a simple decoder. Since the AI and AO 
inputs are being used as inputs to the decoder, they are not used as 
inputs to the gating circuit that provides the decoder-enabling sig- 
nal, A simple example of this is shown in Fig. 2-9. In this circuit, the 
ADDRESS ENABLE signal is generated by a gating circuit (Fig. 
2-5). In this case, the jumpers associated with the Ai and AO address 
inputs are simply disconnected. 

If we assume that the high-address gating circuit has been preset 
for an address bit pattern of 11110000, and that the Al and AO inputs 
to the circuit have been disconnected (see Fig, 2-5), then the de- 
coder shown in Fig. 2-9 will only be enabled for addresses 11110000 
01101100 through 11110000 01101111. Thus, in this circuit, the de- 
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Fig. 2-9. Decoder used for absolute address selection. 
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coder outputs of 0, 1, 2, and 3 correspond to device a ddresses 61 ,548 
throu^ 61,551, or F06CH through F06FH. Only the WR 61548 de- 
vice select pulse has been generated in this example. Again, an or 
gate or a nor gate is required for each device select pulse that is to 
be generated. 
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Fig. 2-11. SN74LS138 decoder. 
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An alternate approach is to use b oth of the decoder t^euits in the 
SN74LS139 chip, using the RD and WR function pulses to enable the 
decoders. In this way, the address selection is again nonabsolute, but 
the device select gating Is performed within tbe chip. This is shown 
in Fig. 2-10. The nor and or gates are no longer required for each 
device select pulse to be generated. While this circuit may not be 
immediately useful, it does illustrate the use of the enable input of 
the decoder to generate the device select pulse. The decoder gatii^ 
CH" enabling input may be used for device select pulse generation, or 
fior al»olute decsoding. In some sases^ it msc^ be used for both. 

There are additional decoder circuits that will be useful to you in 
interfacing your Apple computer to external devices. These decod- 

functional block dtsgrsni and Khtmatlcs Ot inputs and outputt 
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Fig. 2-13. SN74155 dacod«r. 



FLWCTtOW TABtf S 
2-LINE-TO-d-LlNE DECOOEn 
OR 1-LIME-TO-4-LINE DEMULTVLEXEH 



ers, depending on the type you choose, may have additional inputs, 
enable lines, and outputs. Examples are shown in Fig, 2-11 for the 
SN74LS138 decoder and in Fig. 2-12 for the SN74154 decoder. The 
SN75155 decoder has also been included ( Fig. 2-13) since It has two 
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sections, but the address inputs, A and B, are common to both of the 
decoder sections. Each section of the SN74155 has separate control 
or enabling inputs. 

A large decoder .such as the SN74154 4-line to 16-Iine decoder pro- 
vides broad address decoding flexibility. A single SN74154 decoder 
may be used to nonabsolutely decode 16 addresses, and when either 
WR or RD is used as one of the enable inputs, the SN75154 may be 
used to directly generate 16 device select pulses, without the need 
for additional gating. This is shown in Fig. 2-14. 

Additional decoders or gates may be added to the basic circuit so 
that absolutely decoded device select pulses are generate d. A typical 
example of this is shown in Fig. 2-15. Either the RD or WR signal 
may be used to gate or enable the lower decoder. The nor gates 
have been used to gate together the address selection signal from the 
upper portion of the circuit and the address selection plus the func- 
tion puke from the lower decoder. Thus, the upper portion of the 
circuit is used to "qualify" the outputs from the lower decoder to 
make the address selection absolute. In this example, two device 
select pulses have been shown. Although this circuit will work, it is 
not particularly useful, since it can be simplified. 
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#e«f41S4 decDders ttave two enaMfef Ihprafe, M awS. G®, 
the NOR gates shown in Fig. 2-15 may be eliminated by using the 
second enabling input as the "qualifier" that will enable the decoder. 
The use of this type of circuit is shown in Pig. £-16. In this exam ple, 
the lower decoder now has two enabling input signals, the RD con- 
trol signal from the computer, and the enabling signal from the up- 
per portion of the circuit. You should note that the upper decoder 
has both of its enabling inputs used, so that it is enabled only for it 
i^ecific pattern of bits on the HI address bus. In this case, gating has 
been used to generate the enabling signal for the upper decoder. 

A third decoder could be added to this circuit to generate device 
iselect pulseste" Output devices. T%e lnpirts to &ism)ifcia9gg8J dec oder 
would be the same as those to the lower decoder, ese^t Aaft th© WR 
signal would be used instead of the RD signal. 

^te^ decoder sch^^es are pOssMe, ancl you wffl %mm ara «f^ffitp» 
tunity to explore the use of decoders in the experiments. The main 
point is that the use of decoders simplifies the process of device se- 
lection and gating. Decoders are generally used in situations that re- 
<|ftire flexibility and the gpaeratic)!! of several device select ar device 
iiidress signals ip, presia^^' ta me gne^isi;. 
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Using Comparalors 

giiihess detection will be 
the last technique discussed. The comparator-based schemes are rel- 
atively straightforward and they are very similar to the "program- 
ittaMe^gate*" seheiftes sbtJvwi in Figs. 14 raid t-5. Hemember fliat 
comparators, too, are simply collections of gates, connected or inte- 
grated, to perform a comparing function. The comparator circuits 

siSsm mt!0!pmmS:m itddr^ss ii^fls msB^l^aiSifi0^m^mm^'t&. the l^^ 
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bit values on the address bus. This comparing is done by gating 
circuits within the comparator chips. A typical comparator is the 
SN7485 4-bit magnitude comparator, shown in Fig. 2-17. Besides 
the equal condition, the SN7485 can also detect ttie greater-than 
and less-than conditions, but these are not used in address com- 
parison. Caution: The SN74L85 version of the SN7485 chip is not 
a pin-for-pin equivalent. Consult a manufacturer's data sheet for 
additional information. 

A typical address -comparison scheme is shown in Fig. 2-18 in 
which only 8 of the 16 address bits have been showTi for clarity. 
The comparators have been preset to detect the address 205 or 
IIOOIIOI2. Like an 8-input gate circuit, this scheme can only detect 
a single address, so most comparators are used with decoders for a 



flexible decoding scheme, as shown in Fig. 2-19. The unique "equal 
condition" output of the SN7485 comparators is a logic one, so where 
necessary, it has been inverted to provide the enabling signal to a 
decoder chip. In this circuit, two additional comparators have been 
used so that the device addresses are absolutely decoded. Now, the 
outputs of the SN74154 decoder are only active when address bits 
A15-A4 match the corresponding logic states that have been preset 
at the inputs to the three comparator circuits. In this case, the ad- 
dress bits must be 11101001 for A15-A8 and 0000 for A7-A4. Since 
the WR function pulse must also be present to enable the decoder, 
you should realize that output device address selection signals are 
being generated by this circuit, for addresses 59648 through 59655, 
or E9D0H through E907H. Another SN74154 decoder could be added 
to this circuit to generate 16 device address selection signals for in- 
put devices. You would need par allel^ connections between the inputs 
of bot h de coders except that the RD signal would be used in place 
of the WR signal. 

This completes our discussion of device addressing circuits and 
the combinations of device addresses and function pulses to obtain 
device select pulses. In future exa mples, we will expect that you will 
recognize the notation WR 54390 as a l ogic- zero device select pulse, 
generated by the proper gating of the WR function pulse and ad- 
dress 54390. In some cases, the actual gating will be shown, but in 
most cases, we will assume that you understand the origin of the 
signal. While you will probably see many different device addressing 
and selecting circuits in other books, magazine articles, etc., you will 
quickly find that they all function in pretty much the same way- 
gating an address signal with a function pulse to select a particular 
device. 

In some of the experiments, you will explore the use of device 
select pulses to control devices. In the next chapter, you will learn 
how these pulses are used to control the flow of 8-bit data bytes on 
the data bus of the 6502. 



I/O Interfacing 



Now that we have developed a number of ways of selecting and 
identifying I/O devices, the actual construction and configuration of 
t{M i/@ ports become very important. In this section, we will de- 
velop some of the actual bus interfacing schemes that will allow I/O 
devices to transfer 8-bit bytes to the computer and to receive bytes 
tesn^tferred to them by the eoanputer. As we found with the device 
selecting circuits, there are many circuits for input ports and outpu^t 
ports. Only a few sample circuits will be provided to illustrate th© 

OUTPUT PORTS 

Output ports are devices that receive data hytes from the com- 
puter, conftrolfed % POKE commands to ffie Bi^SlG-language pro- 
grams. You have already seen that the re is a definite timing relation- 
ship between data on the bus^ the WR pulse and the device address, 
isfei a CKanmaiicf fs i^eeatiesii %liis heen shown in Pig. 

1-4, In the Apple computer, th e dur ation of the WR pulse is about 
500 nanoseconds. If we use the WR pulse to gate the data from the 
^da^ tes ta ajl otttptit device, through the use of the device select 
pulse, the data is only presented to the output device for about 500 
nanoseconds. This period is hardly long enough to allow the receiv- 
iMg device to peti&M a function. To eteafffflSte this prob- 

lem, each output port must be equipped with some sort of circuit 
that can acquire data from the bus and "hold" it for as long as 
needed, or until it is "updated" by another data transfer. 

The type of circuit that can perform this f uoctio!;! is <3*]Ued a latch, 
since it can latcli the information and hold it WM. II U apdtted OF 
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until the power is turned off. There are many different types of latch 
integrated circuits that offer different configurations of control and 
data inputs and outputs. Rather than describe all of the various types 
of latches, we have chosen to describe three general-purpose devices, 
the SN7475, the SN74175, and the SN74LS373. The pin configura- 
tions and function tables are shown in Fig. 3-1. While the SN7475 
and SN74LS373 are true latch devices, the SN74175 really contains 
flip-flops. The SN7475 latch chip contains four latch circuits and the 
SN74175 contain-s four flip-flop circuits, so two SN7475 or two 
SN74175 chips are required for each 8-bit output port. The 
SN74LS373 contains eight latch circuits, so only one of these is 
required to construct an 8-bit output port. 

Let us briefly describe the operation of these latch circuits, so that 
their use becomes apparent. We will use the SN7475 latch chip as 
an example. The SN7475 latch circuits can be thought of as "gates 
that remember." This is shown in the function table for the SN7475 
latch, shown in Fig. 3-1. In examining this function table, you will 
note that when the enable input (G) is a logic one, the data, or logic 
level present at the "D" input, is passed through the latch to the "Q" 
output. The Q output is the inversion of the Q output. When the 
enable input goes from a logic one to a logic zero, the level present 
at the D input at this time is latched or remembered by the Q and Q 
outputs. The timing relationship shown in Fig. 3-2 illustrates these 
operations. 

As soon as the "G" input goes to the logic one level, the Q output 
assumes the state of the "D" input even if the levels at the "D" input 
are changing. The logic levels are passed from the "D" input to the 
"Q" output when the "G" input is a logic one; the "Q" output remains 
at the level of the "D" input when the "G" input goes to a logic zero. 
The SN7475 is divided into two sections, each of which can operate 
independently of the other. The two gate inputs may be connected 
to make the four latch circuits operate in tandem. Of course, the in- 
puts and the outputs to the latches remain independent, so that four 
input signals may originate from different places in a circuit. How- 
ever, all four inputs will be latched at the same time if the separate 
functions are operated in tandem. 

The SN74LS373 operates in the same way as the SN7475, although 
only one gating or enabling signal is used. In this chip, only the Q 
outputs arc provided. The Q outputs are not available. An additional 
output control has been provided, but when the SN74LS373 is used 
as an output port, this control signal. Output Control (pin 1), is usu- 
ally grounded. 

The SN74175 chip contains four flip-flops that acquire and hold 
information that is present on the poyiiive-going edge of the clock 
pulse. The outputs are only updated at this time, and the inputs are 
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Fig. 3-1. Pin configuralieiis and function tables for SN7475 (top), SN74LS373 
(middle), and SN74175 (boHom) latch chip*. 



not continuously gated through the SN74175 on either the logic zero 
or the logic one portion of the clock signal. This is what distinguishes 
this flip-flop device from the latch devices, although in computer in- 
terfacing, the net effect of both types of chips is the same. 

A common clear input is also provided on the SN74175, so that the 
flip-flops may be "cleared" (Q=0, Q=l), when this input is taken to 
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Fig. 3-2. SN7475 tatcb tircuit timing rabtionthipt. 



the logic zero state. In most cases, the clear input will be connected 
to +5 volts (logfe tsae) jftid'wffl adt bet^^ 

Each of the integrated circuits may be used to latch and maintain 
the data put out by the Apple computer during the execution of a 
POKE GOfltlinand. It is a simple matter of using an output device 
select pulse to giqtivite the latch circuit once it has been properly 
connected to the bus. A typical 8-bit output port is shown in Fig. 3-3. 
In this circuit, a logic one output device select pulse is required to 
cause the latch circuits to acquire and hold the inforcnation putpflt 
by the Apple. 



SH7475 




Fig. 3-3. Two SN7475 latch chips used to form an output port. 



In Fig. 3-4, two SN74I75 latch chips have been used as an output 
port, wdth some sort of logic monitors being used to provide a visual 
iiidf^rtiiOn of the information that has been latched by ^e chips. The 
"1" indication at the connections to the CLEAH IegwtS at the output 
port means that these inputs are connected to +§ ¥0118, or a logic one 
level. The "1" notation is used to distinguish a logic level connection 
from a power-supplying coniiectionjs wJwch is noted as -1-5 volts, or 

An SN74LS373 8 -bit or octal latch has been used as an output port 
as shown in Fig. 3-5. Only one integrated circuit is required for this 
oatp^ piCfft, The Oujput Control Hue has been grotmdfed so &at the 
outputs are permanently enabled. Again, an output device select 



SH74175 



DATA BUS 




OUTPUT 
PORT 
DATA 



Fig. 3-4. Two SK741 75 latch chips uied to form an output port. 



pulse must be supplied from the device selection logic. Once an out- 
put port has been properly connected to the data bus and a source 
for the device select pulse, it can be accessed under control of soft- 
ware commands. For example, the command, POKE 49312,0 would 
transfer the value zero to the output port with the address 49312, If 
there is actually an output port connected to the data bus, which cor- 
responds to this address, then the value zero would be transferred 
to it. 

The program shown in Example 3-1 may be used to generate an 
increasing binary coimt at output port 49320. The count will con- 
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tinue in sequence (in binary), 255, 255, 0, 1, 2 . . . 254, 255, 0, 1, etc. 
This program will be seen again, in the experiments. 

Example 3-1. An 8-Bit Binary Counting Program for Port 49330 

10 FOR N = TO 255 
20 POKE 49320,N 
30 NEXT N 
40 GOTO 10 

Output ports are rather easy to construct. Most parallel-in, paral- 
lel-out logic devices with internal latch capabilities can be used as 
latches. Examples of devices that can be used as latches are the 
SN74193 programmable binary counter, the SN74LS194A universal 
shift register, the SN74198 shift register, etc. 

Most output ports are readily configured with standard inte- 
grated circuits, but some of the newer integrated-circuit devices that 
are meant specifically for use with microcomputers are becoming 
available with built-in latch functions. An example is the Signetics 
NE5018 8-bit digital-to-analog converter chip which contains a latch 
section. 

Typical applications for output ports include the following: 

Transfer data to a printer 

Transfer data to a video display 

Control a traflBc light 

Transfer data to a floppy disk 

Actuate switches on a model railroad 

Control valves and pumps in a chemical process 

Control a plotter 

Transfer data to a seven-segment display 
Control another computer 

In some applications, the value of the information is actually used, 
while in others, the on or off state of each bit is used. Some devices 
such as a printer may use a combination: ports for the transfer of the 
data to be printed and ports for the control of the printer functions. 
Displays made up of seven-segment LEDs frequently require the 
use of several output ports, even though the display is considered to 
be only one "device." 

INPUT PORTS 

Input ports are used with I/O devices so that they may transfer 
information to the computer in 8-bit bytes. Unlike output ports that 
must be able to accept and hold information that is placed on the bus 
at a specific time, and may be continuously connected to the data 
bus, input ports must be able to "disconnect" themselves from the 
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Fig, 34. Atlcmpted u» of standard gatos on a data bus. 

bus when they are not in use. The input ports must pass logic ones 
and zeros to the CPU, but they must be configured .so that they do 
not interfere with the use of the bus when they are not selected. 

Depending on the type of gate chosen, simple gates cannot be 
used to gate data onto the data bus lines since their "unselected" out- 
put state will be either a logic one or a logic zero, as shown in Fig. 
3-6. Note that even when none of the gates is selected or enabled, the 
outputs of the gates are at different logic levels, as noted by the 
quoted logic levels. These levels "compete" for the use of the bus, 
probably leading to one or more burned out chips. This should 
clearly illustrate why gates alone are not used on data buses. 

yCC _fC *A *V 3C 3A 3V 
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Fig. 3-7. SN741 25 bus buffer chip 
pin conflguratien. 
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Special integrated circuits with three-state outputs are available 
to simplify the design of input ports. A typical three-state device is 
the SN 74125 bus buffer, shown in Fig. 3-7. The diagram of the four 
devices should look familiar. It is simply a buffer ( logic one in, logic 
one out, etc.), but with an additional control line, shown connected 
to one of the angular sides of the buffer symbol. The buffer will pass 
logic ones and zeros from its input to its output when it is enabled, 
but unlike a simple gate, when it is disabled, the output appears to 
be electrically disconnected from the bus, or other logic device, to 
which it is connected. In three-state devices, this third .state is often 
called the HI-Z or high-impedance state, to note its disconnected 
condition. The disconnecting and connecting is rapid, generally tak- 
ing less than 20 nanoseconds. 

In the SN 74125 circuit, each three-state buffer has its own enable 
input, which must be a logic zero for the data to be passed from the 
input to the output. A logic one state on the enable input forces the 
output into the high-impedance state. A similar integrated circuit. 
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Fig. 3-8. Typical three-stale bus for four devices. 

the SN74126, is a pin-for-pin replacement for the SN74125, except 
that it is enabled with a logic one and di.sabled with a logic zero. 
These chips serve to illustrate the action of three-state devices, but 
they are not generally found in computer interface circuits, since 
more useful devices are available. 

For purposes of illustration, a typical bus is shown in Fig. 3-8. In 
this circuit, four one-bit devices have been connected to the bus. 
Only a one-bit bus is shown for clarity, although in an 8-bit bus sys- 
tem, eight lines would be required. When one of the BUS ENABLE 
INPUTS is placed in the logic zero state, the corresponding data bit 
is passed through the buffer and onto the bus. We will assume that 
there are no other devices connected to the bus. Thus, the truth table 
shown in Table 3-1 applies to this simple bus circuit. 

When none of the buffers has been enabled or connected to the 
bus, the bus is not connected to anything except the input of the 
gates, memories, etc., that are the "receivers" of the data bit, so the 



Table 3-1. Truth Tabis for a Four-Device Three-Slate Bus 



Enable 
D C B A 


Bus Content 


1111 

T 1 1 
110 1 
10 11 
111 



Undetermined (all devices Hl-Z) 

Data A 

Data B 

Data C 

Data D 

Not Allowed 



SI 



logic value of the bus is unknown. Whenever a logic zero is applied 
to one of the bus buffer enable inputs, the selected buffer passes its 
data onto the bus. The condition in which more than one buffer has 
been enabled is not allowed, since bus conflicts will arise. 

AH of the devices that are to be used with the Apple computer 
system to transfer information to the CPU mmt have three-state out- 
puts. Thus, even memory chips must have three-state outputs, as 
they in fact do. The computer designer must be sure that the system 
has been designed so that no two input devices are selected at the 
same time. If such a multiple selection takes place, improper opera- 
tion of the computer occurs. 

Input ports that may be used to transfer information to the com- 
puter are readily constructed using standard three-state integrated 
circuits. In most cases, eight individual three-state buffers are used, 
one per bus line. In most cases, too, the enable inputs are all con- 
nected in parallel, so that all eight buffers transfer their information 
onto the bus simultaneously. In some cases, the common enabling in- 
put is provided within the chip so that only a single pin on the chip 
is required for the control of all eight bits. 

There are many chips that may be used to construct input ports, 
but only a few of them are general enough to warrant our considera- 
tion. The two main integrated circuits that will be used in our exam- 
ples are the SN74365 and the SN74LS244. The SN74365 may also be 
noted as the DM8095 (National Semiconductor Corp.), which is an 
exact replacement. The pin configuration for these two chips is 
shown in Fig. 3-9. 

You will note quickly that while the SN74LS244 has eight three- 
state buffers on one chip, the SN74365 has only six, If the SN74365 
device is used to construct an input port, two of the integrated circuit 
packages must be used. A typical 8 -bit input port is .shown in Fig. 
3-10. In this case, only two of the three -state buffers in the lower 
SN74365 chip have been used. Since the SN74365 contains built-in 
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Fig. 3-«. SN74LS244 and SN7436S (DM809S] rhre«-(tat« but driver chip 
pin configuration. 
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NOR gates that control the enabling of the three-state buffers, these 
have been u sed to gate the RD functi on pulse a nd the device ad- 
dress, 49321. If the device select signal, RD 49321, had already been 
generated elsewhere in the interface circuit, it could be applied to 
one of the enable inputs on both chips, while the other enable inputs 
were grounded, or logic zero. This control scheme is shown in Fig. 
3-11. 



INPUT PORT 




TO 
DATA BUS 



Fig. 3-10. Typical input port constructed using SN74365 chips. 

Using such an input port, data values may be input to the com- 
puter through the use of the PEEK command, as shown in Example 
3-2. 

Example 3-2. Data Input Program for Port 49331 

10 A = PEEK (49321) 
20 PRINT A 
30 GOTO 10 



RD 49321 



r 



SN74365 
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Fig, 3-11. Alternate control scheme for SN74365 thre«-(tate chipi. 



In this example, the 8-bit binary value is converted to a decimal 
number between zero and 255 when it is input by the Apple using 
the PEEK command at line 10 in the program. It is then "printed" on 
the video monitor screen. It would have been just as valid to use the 
following command; 

10 PRINT PEEK(49321)i GOTO 10 

A similar input port may be constructed by using an SN74LS244 
octal (8-bit) buffer. This chip contains two independent sets of four 
buffers each, which are independently controlled with two enable 
inputs, 2G and IG. Since there are no built-in nor gates in the SN74- 
LS244, external device select gating is required. A typical input port 
in which an SN74LS244 chip has been used is shown in Fig. 3-12. 
Software steps similar to those shown in Example 3-2 would be used 
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Fig. 3-12. Input port canflgurvd wMi an SN74tS244 chip. 



to control the flow of information from this port into the computer. 
Both the SN74365 and the SN74LS244 have pin-for-pin equiva- 
lent circuits that invert the data bits as they are passed through the 
chips and onto the data bus. These buffers are the SN74366 and the 
SN74LS240, respectively. The SN74366 is also equivalent to the 
DN8096 chip. In most cases, the noninverting buffers will be the ones 
used in interface circuits. 

In some cases, peripheral devices may generate more than eight 
bits of information that must be read by the computer. An example 
of such a device would be a 12-bit analog-to-digital converter. When 
more than eight bits of information are to be input, the bits are di- 
vided into groups of eight bits. In the case of the 12-bit converter, 
there would be two groups, one containing 8 bits, and the other con- 
taining the remaining four bits. Likewise, a 16-bit value would re- 
quire two input ports, as would a 9-bit value. When not all eight bits 
in an input port are used, the unused bits are generally placed in the 
logic zero state by connecting them to ground, or logic zero. If the 
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j^te of ifce titlused bits cannot be determined, perhaps they have not 
actually been constructed in the input port circuit. You can "elim- 
inate" these bits by using appropriate software commands. These 
omumnds '^midi^ th^ vhiq^ Mis, m ^t fliey became z)b«c^. 

Since a 12-bit value may represent decimal values between and 
4095, some means must be found for converting the individual bytes 
that have been input into a single villteet vs&i Histfnie ihat tke 
eight least-significant bits have been input as a single byte from port 
49312, and that the four most-significant bits have been input from 
input port 49313 at bit positions D3-D0. We will further assume th^ 
die unused bits at input port 49313 have been grounded so that they 
are logic zefOS. 

Now that the configuration of the input ports has been defined, 
let's see how the information is manipulated so that the original value 
k SiiSJiistTucted from the two separate bytes of data from the two In- 
put ports (Fig. 3-13). Since the least-significant bits can represent 
values between and 255 from the 12-bit interface device, these bits 
do not m^0M mif^ ^maivm^m,'' since tibe Apple will $liiipily loime 



these eight bits and convert them to a value within the range of to 
£55. However, if the four most-significant bits are considered apart 
(lotA iSm other bits, conveaiing tbsM w ^^minml '^tm^d^ 
tween and 15, rather than their original positional values of 0, 256, 
512, and so on. These bits have been "offset" by a factor of 250 dne 
to ibe fact that the 12-bit data value had to be "split" into smi^m 
pieces so that it could be input by the Apple. Remember that any 
8-bit value that is input into the Apple will be automatically con- 
verted into a decimal number with value.s in the range of to 255. 

When the two values have been input into the Apple, it is a simple 
matter to "reconstruct^ the data. If the information from the four 
most-significant bits is multiplied by 256 and then added to the value 
from the eight least-significant bits, a resulting value will represent 
values beiv^ii^ a^nd W^, iadii^h^, llhe viiSe tibi^ ^^iis cniginally 
present as a 12-bit binary value at the interface device. The ccnn^lj^ 
software routine is shown in Example 3-3. 




DATA BUS 



Rg. 3-13, Two-bil ii^ pMl, 



Exampl* 3-3. Pregram for a 1 Z-Bit Input Canvcruoit 

10 A = PEEK{49312) 
20 B = PEEK(49313) 
30 C = (B * 256) 4- A 
40 PRINT C 

You could simplify this by placing all of the steps on one line: 

10 PRINT(PEEK(49313) * 254) + PEEK(49312) 

This simple program will print the decimal equivalent of the 12-bit 
binary value that was present at the peripheral or interface device 
when the program was run. The program can be used for interfaces 
with from 9 to 16 binary outputs, but you must be careful to ground 
the unused bits. You will see another method of "masking," or clear- 
ing the bits in the experiments. 

Input ports are used to transfer information from external devices 
to the computer. This information may represent actual values of 
weight, temperature, resistance, etc., or the information may be in- 
terpreted as individual binary bits representing the state (on or off) 
of individual devices, for example, empty/full, ready/busy, etc. 
Some typical uses for input ports would include the following; 

Transfer of traffic sensor information to the computer 
Transfer of digital values from an instrument to the computer 
Transfer of status (on-off) bits from a printer to the computer 

In interfacing applications, the main requirement for input ports is 
that their outputs have three states so that they will not cause con- 
flicts on the data bus when they are used. 



CHAPTER 



4 



Flags 




Decisions 



In almost; all of the previous examples, we have assumed that there 
is little synchronization required between the computer and the ex- 
ternal I/O devices. Thus, output ports have been assumed to always 
be ready for more ^ta %9 be transferred to tbenu in tbe csase QjE input 
jmrts, we have assumed tiiat the data vaihies arie pr^esfettt and tm&y 
for transfer to the computer, when the computer reaches a PESE 
command in a program. This may not always be the case. We muit 
oSbm dssl tvidii I/O devices diat are slowra" than ibe mmpiiiit&t. 



Since not all I/O deytees SKif he ready for the mmmv^ at all 
times, a means of synifconizftig fbe ctmpn^lm m& tlie f /O devices 
is required. The synchronization generally in:pi^i^ the use of signals 
that are called flags. These signals are used ^ indicate that various 
de^dceii wee hmy or not hmy, tmdf (iit m/k iegtAy, converting or not 
converting apd so on. Thus, "flags^ lndic^tiie stetqs of devices, and 
they are often called status ftags. 

For illustrative purposes, we will assume that we are required to 



sStS^^tee a device ta $m Apple coin^iiter, The device \vill provide 
S-bJt data values to tsjiuputer du m iitegular l>asis, tn most cases, 
such devices also generate a flag signal that indicates that the device 
is ready to transfer its information to the computer. Such a device is 
showif in Fig. 4-1. l%te tttat a staadeo^ ^ree-state ioptit poart las 
been used to transfer the information to the computer. The READY 
flag presents an interesting problem. How is the computer going to 
Miutcir or check the condition of the READY flag, SO that It CWl 
di^enniQe when a new data value is ready? 



I/O DEVICE SYNCHRONIZATION 



INPUT DEVICE 



READY/BUSY 
D7 



DO 



SYNCHRONIZING FLAG 



INPUT PORT 



J 



■ D7 



TO DATA BUS 



DO 



RDXYZ 



F!g. 4-1 , Simple input device with synciironiring fl«g output. 

As we stated previously, there is no rule that limits input ports to 
the transfer of actual numeric values. The computer ha.s no way of 
knowing that the 8-bit value, 01100100.J, represents 100, rather than 
five devices being off, and three devices being on. Thus, another in- 
put port could sei-ve quite well as a way of transferring the status flag 
information from the input device to the computer. The other seven 
bits at this input port may be unused, or they may be used to indicate 
the status of other external devices. In this way, software steps may 
be used to check the condition or status of external devices. 

When the status of a flag is checked in a computer program, the 
computer may be programmed to wait until a flag has changed to a 
particular state before going on with the required action, or it may 
be programmed to check the flag periodically, going on about other 
tasks in the meantime. 

There are logic operations in assembly language and in BASIC 
that allow us to check the status of individual flags, or bits, in an 8-bit 
data word. In this way, the actual logic zero or logic one state of a 
flag may be detected, with the computer making a decision based 
upon the state of the flag. 



LOGICAL OPiRATIONS AND FLAGS 

Probably the most useful operation, where flag detection is con- 
cerned, is the logic and operation. You should recall that two bits, 
A and B, may be "ANued" together, as shown in Fig. 4-2. The result 
indicates that only when both of the bits are logic ones will the result 
be a logic one. Another way to think of this is to treat the "A" bit as 



AND GATE 

Fig. 4-3. ltepr«Miit«tion of logical AND operation uiing DATA end MASK te 
yield RESULT. 



ymw 00111010 oooiioio iiiioooo oooiiiii 

MASK 00100000 00100000 00100000 00100000 

RESULT 00100000 00000000 00100000 00000000 

Fig. 4~3. Example ef AND oparalion in which eight bits of information an 

a %iai5k" and ilie TS^feft as inforiinatiefii m data. When tibe itiiiask is 
a zero, the result is a zero. When the mask is a one, the data is passed 
through the gate. In this way, selected bits may be masked, while 
others are "passed through" the mask. If, for example, we wished to 
check the state of bit D5 in the data word OOHIOIO, a mask of 
00100000 could be used. The mask is ANBed With the data word, as 
shown in Fig. 4-3, for several di£Eerent data words. In all cases, the 
logic state of D5 was gassed through to bit D5 in the result. AH of 
■ft®' d&m It^S'^'mm msdk'e^, m-isBf ^s mm. In flit 'mtf, '§m tefc^ "ks^ 
suit was zero when bit D5 was zero, and the result was nonzero when 
bit D5 was a one. This could be used as the basis for decision making 
steps in a program. You must reiis^tKir to convert the masks to their 
decimal equivalent before trying to use them in a BASIC proband- 
In the case of bit D5, the mask would be converted tQ ^ 



Once an interface has been constructed so that the states of the 
various flags may be detected, as shown in Fig. 4-4, software may be 
ttssd^ make decisions based upon the states of the flags. 

In some dialects of BASIC, there are logical operations that will 
perform bit-by-bit and operations, such as the ones shown in Fig. 
4^ hi flcese eases, ^mgle ptfi'^ioiis may be used in BASIC pt>D- 



INPUT DEVICE iMIllWTPORT i -jpr- RD ^1 
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RD 49320 



Hg. 4-4. Compiot* intarface in which the fl«g it datactad by toftwan*. 



Eipa^ 4-t< A t«||{c Zm Itairf far ibMni 

40S@ . . . CoRttnua tm» if ft^ » logic oiia 

grams to perform the ANDing operations between two data words 
that have values between and 255. Keep in mind that the binary 
equivaients are what is actually being ANDed. Examples 4-1 and 4-2 
illustrate how these anb operations could be used to detect a flag 
that is input at bit D5 from mi input port, port 49321, 

Example 4-3. A ti^ €NM 11^ llMl fer CeiilMl 

4010 A = PEEK(4932I) 

402O IF (A AND 32) > THEN 200 

4030 . . . Continue here if flag = logic zero 

In either case, when the proper condition is met, the program 
would probably input data from an input port, or perform some other 
action that is signaled by the presence of the flag. 

Unfortunately, the Apple computer does not use its logical com- 
mands in this way. In flie Apple, an and operation allows only the 
ANDing of two distinct true-or-false conditions, so it is very difficult 
to mask eight bits to determine tbe state on only one. Unless we wish 
to spend a great deail dl fhne in a complex BASIC routfne, tre n^st 
GCNOsider the nse of an assembly-language subroutine that will per- 
form tlie logical operations for us rallier quickly. Since you can easily 
point the Apple to assemldy-Iai^aage routines, tbis is worth p[tii8u- 
ing a bit further. In fact, we will provide you with some simple, easy- 
to-use routines. 



ASSEMBI.Y-LAII@tlA^ LOGICAL OPERATIONS 

The assembly-language instruction set for the 6502 microprocessor 
ciontains an ajvd and an ok operation. Each of these instiucllion^ wiU 
operate upon two bytes, providing a single byte a«&i i?^^ cl 
the operation. Thus, vfc must M«ite a siiort routine that will peifoim 
the operation. 

The Apple provides some "qwa^ jSMtd/wite memory locations on 
memory page 03H, and we have chosen to locate our routines on this 
page, since it will make the routines independent of the total memory 
size of your computer. A complete listing for the routine is |Kr0^ir£cted 
in Table 4-1, Note that both hexadecimal and decimal addresses and 
data /instruction values are provided for you. You do not have to be 
an expert in assembly language programming to use this routine, but 
we have provided some comments so that you can follow the opera* 
tian of the program, if you wish. 



m 



Address 


Byte 


Data Byte 




Haxa decimal 


Decimal 


Haxadaciaid 


Paclgial 


0300 


768 




— 


MASK Byte Goes Here 


030 i 


769 


— 


— 


DATA Byte Goes Here 


0302 


770 


— 


— 


ANSWER Found Here 


0303 


771 


43 


72 


PHA Push Reg A 


0304 


772 


AD 


173 


LDA Load Reg A from 


0305 


773 


00 





MASK loaKon 


0306 


774 


03 


3 




0307 






AS 


AND tt»9 A with DATA * 


0308 






1 


0309 






i 




mm 


778 


1^ 








m 








030C 


m 




3 




030D 


m 


■m 




pyst PvHi t^. A Iw^ 


030E 


782 


60 


96 


RTS R«tum to MStC 



*Sul»tltu1« OOH, or 13 decimal, for an OR operation. 



Three read/ write memory locations are used for the temporary 
stoia^ of v9skm datg. bytes, ci^ed MASK, BYTE, and AN- 
SWER, 'rite MASk IbcEtttett !is Toaled Wfh fte nOBsk byte, aftd ihe 
BYTE location is loaded with the byte that is to be operated on. After 
the logical operation has taken place, the ANSWER location contains 
the n^ult 

To use this routine, you need to load the M.ASK information into 
address 768, and the DATA byte into address 769. You can use 
POKE operations to do this. Once this is done, you simply need to 
call the assembly-language subroutine, so that the operation is per- 
formed. How do you do this? 

Calling an a.ssembly-language subroutine from BASIC is not very 
difficult. In the Apple computer, you simply need to put a three-byte 
jtttnp itatracftion in tfaee sEieee^fve loeali&ns, addt^sses 10, 11, imd 
12, or OA, OB, and OC, in hexadecimal notation. Since our routine 
starts at address 771, or 0303H, you need to put the following infor- 
mation in these three locations: a 76 in address 10, a 3 in address 11, 
and a 3 in address 12. Once you have loaded this address information 
into these three locations, you can access the assembly-language sub- 
routine with a USB function. In this case, you need to fir.st load the 
MASK and BYTE information, and then use the USR function. This 
is <sh(mn fn Bssmnpfe 4^. 

In this case, the value 32 is the mask byte, and 129 is the value that 
is to be ANDed with it. The Q is a "dummy" variable that is required 
for the use of the USR function, and the "Wlim B a ISummy" value 
that has no effect on the subroutine. You &m use my vsuiable for Q, 

«i 



ExampI* 4-3. Calling lha Logical Opwation Subroutine 

1590 POKE 768,32: POKE 769,129 
1594 Q = USR(5) 

as long as you don't use it elsewhere, and you may substitute any 
value for the 5, say 0. 

Once you have called the assembly-language subroutine, you will 
find the result in location 770, and a PEEK operation may be used to 
get at it. The program shown in Example 4-4 shows the complete use 
of the subroutine. We have assumed that the subroutine has been 
loaded, probably through the use of the monitor. In this example, the 
three-byte jump instruction is loaded by using POKE operations. 

ExampI* 4-4. Using the Logic Oparatien Subrouting 

2030 POKE 10,76: POKE 11,3: POKE 12,3 

2040 POKE 768,32: POKE 769,PEEK(49321) 

2050 Q = USR(7) 

2050 IF PEEK(770) > THEN 3460 

2070 . . . Continue here if flag = 

In this example, the data to be used in the logical operation is ob- 
tained from an input port by using a PEEK command and the ad- 
dress for the device. 

You can also perform an ok operation with the same subroutine, 
simply by changing the operation code ( op-code) for the and opera- 
tion from a 2DH to a ODH. Again, a POKE operation can do this just 
before you use the subroutine. Thus, the subroutine provided in 
Table 4-1 can be used for both logical operations. 

You should be able to load the subroutine into the read/ write 
memory by using the monitor for the Apple. We refer you to the 
Apple 11 Reference Manual for information about the monitor. You 
could also use 12 POKE commands to load the program steps, but 
this invites errors. 

It is unfortunate that you must resort to assembly language to per- 
form the logical operations that are readily available in other BASIC 
dialects. However, the assembly-language program is fairly simple, 
and it has provided a simple example of the use of such programs, 
and how they can be called from a BASIC program. If you are not 
an assembly-language programmer, perhaps this has whetted your 
appetite. 

COMPLEX FLAGS 

At this point, you may be asking, if the flag on the input device 
shown in Fig. 4-4 is used to indicate the availability of an 8-bit value, 
how does the device know when the computer has input, or ac- 
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INPUT DEVICE 



_n_ 



READWBUSY 



D7 



DO 



CLEAR FLAG 
1= 



RD 49321 



D7 



TO DATA 
BUS 



DO 



RD 43320 



Fig. 4-S. Compista flag circuit in which flag is cleared by computer-genersled pulie. 

cepted, the value that it has made available? In some cases, a signal 
from the computer to the I/O device is used to indicate that the flag 
has been detected, and that the necessary action has taken place. 
This signal "clears" the flag. The flag-clearing action may be per- 
formed by a separate signal. The same signal that controls the input 
port for the data may perform the flag-clearing action. This is shown 
in Fig. 4-5, and a simple timing diagram is shown in Fig. 4-6. 



READHBUSY FLAG 



R()483Z1 



RD49320 




Fig. 4^. Flag liming diagram. 



When the flag is placed in the logic one state, this indicates that 
the device is ready to transfer a byte to the computer. The RD 49321 
pulse represents the transfer of the flag status information to the 
computer. When the computer tests the flag and finds that it is a 
logic one, it executes the steps that actually transfer the data from 
the device to the computer. The RD 49320 pulse is used here to en- 
able the three-state buffers at the correct time. This pulse is also used 
to clear the internal flag circuit of the device. 

The second RD 49321 pulse again reads the status of the flag, but 
since the flag is now a logic zero, the computer takes no further ac- 
tion. The third time that the flag is tested, however, the flag is a logic 
one, and the data is transferred to the computer and the flag is 
cleared. A simple set of program steps that can be used to control the 
interface is provided in Example 4-5. We have assumed that the logi- 



Example 4'5. A Simple Flag %»g|fiig A^rk^ 

1050 POKE 768,32: POKE 769,PEEK(4932 1 ) 

1060 Q = USR(0) 

1070 IF PEEK(770) = THEN 50 

lOeO D = PE£K(49320) 

1090 . . . Continue here after data input 

Typical devices that use flags in this way are keyboards, floppy 
disJcs^ analog-to-digital converters, and other devices that may pro- 
vide ifeta bytes at irregular perioJb. 

In some cases, devices may not have the necessary flag circuits 
within them for easy flag control, or they may not generate logic 
levels that are stable for reM^ely "long" {i^ods so that they can be 
properly detected by the computer. In these cases, the "flag" may be 
a very short pulse, In fact, some flag pulses are too short to be de- 
tected by the compaterjif daey are; situply input by Mea»s Gfa^tmm- 
state input pioit. 

tn cases sudh ais iMs, ft 'fs neees^atf te design a efrcnfi ttat vpin 
"capture" the flag pulse so that it may be detected by the computer 
sometime lat^r. Even if the computer can test a flag bit every few 
ittffliSRSSHdg, it wfll frequently "irifSi^ sbistrt ptilses el a few micro- 
seconds duration. 

Flip-flop or latch circuits are generally used to remember the pres- 
mm:-i^ iftg pulses. Typical flip-flop devii^ M ^^€f4 fiMlyp© 
flip-flop, and the SN7476 J-K flip-flop. Most introductory digital elec- 
tronics books provide a good coverage of flip-flop devices if you need 
iX) review their operation. 

A typical flip-flop-based flag circuit is shown in Fig. 4-7, In this 
circuit, the input device generates a READY pulse that clocks the 
flip-flop, transferring the logic level from the D input to the Q but-^ 
put. The Q output is detected by the computer through the use of aft 
input port that is separate from the input port that is used for the 
transfer of the eight data bits. The status of the flag bit is easily 
tested by the computer, as has been described. Once the necessary 
acition has taken place, in this case, the input of data fr om the i nput 
device, the flag flip-flop is cleared. A logic zero pulse, CLEAR, ap- 
plied to the clear input of the flip-flop serves this purpose. While the 
ID #Si9 pttlie ttse^ to ig«*lC^ fte^^^^ tffptit port could be used to 
clear the flip-flop, we have shown a separate clear si^al, so that the 
timing relationships can be shown, as in Fig. 4-8. 



INPUT DEVICE 



INPUT PORT 





07 


READY 


DO 



07 



_rU FLAG PULSE 

SN7474 




CK 

CR 

— c — 



l> 



D3 



DO 



DATA BUS 



RD49360 

R04936I 



INPUT PORT 



CLEAR 



Fig. 4-7. Flip-flop circuit used for dalvctton of flag pulia. 

In the timing diagram, the READY pulse sets the flip-flop, so that 
its Q output is a logic one. This is detected when the status flag in- 
formation is input from port 49361. The logic one state of the flag 
causes the software to perform the steps that input the data byte and 
then clear the flag. The separate CLEAR signal could be generated 
by a POKE command, and appropriate circuitry, although the use 
of the readily available RD 49360 pulse is probably easier. 



DEVICE READY [1 
FLAG OUTPUT (0) 
FLAG TEST (IN 28) 
DATA IN (IN 20) 
CLEAR 



JL 



JL 



JL 



Fig. 4-8. Flag flip-flop liming diagram. 



In this example, the flag was tested twice while it was in the logic 
zero state. Since this indicated that no new data was ready, no input 
transfers or flag clears were initiated. 

Several experiments at the end of this book involve the use of flags. 



MULTIPLE FLAGS 



Many systems have a number of flags that must be checked on a 
regular basis. In some cases, a priority must be established, since 
some devices arc more important, or require faster attention, than do 
others. The priority is easily set in the program, since the order in 
which the various bits are tested determines which devices are "ser- 
viced" before others. The program steps shown in Example 4-6 will 
check several flag bits in sequence, from bit D7 to bit D5, providing 
a priority in the order in which the corresponding devices would be 
serviced by the computer. 

In this example, the flag for bit D7 was detected when it was a 
logic one, while the other two flags were detected when they were 
logic zero. Other bit-sensing steps may be added for other flags, and 
the order in which the bits are tested may be changed at any time, 
simply by changing the program to reflect the new order. Note that 
the data involved in the and operation is not changed, and it only 
needs to be input from the input port at the start of tlie sequence of 
instructions. 

Exampls 4-6. Flag Priority Seftwart SKps 

300 POKE 769,PEEK(54098):POKE 768,128: Q = USR(0) 

305 IF PEEK(770) > THEN 1050 

310 POKE 76B,64:Q = USR(0) 

315 IF PEEK{770) = THEN 20 

320 POKE 768,32:Q = USR{0) 

325 IF PEEK(770) = THEN 1010 

330 . . . And so on for other bits 

INTERRUPTS 

In some cases, it is necessary for an I/O device to be serviced as 
soon as it is ready. It may not be able to wait the many milliseconds, 
or even longer periods, that the computer may require to check flags 
and make decisions based upon them. Almost all computers have at 
least one interrupt input that allows you to "demand" immediate 
servicing from the computer, irrespective of what it is doing. The 
6502 processor chip used in the Apple computer has two interrupt 
inputs; an interrupt request input (IRQ), and a nonmaskable inter- 
rupt input (NMI). The IRQ input is sensitive to a logic zero, while 
the NMI input is edge sensitive, being triggered by a logic one to 
logic zero transition. These inputs are not used within the basic 
Apple computer. However, they are readily available at the internal 
interface connectors, and they may be used by add-on peripheral 
devices and interfaces. 

If a device is going to require extremely fast servicing, fast enough 
to require the use of an interrupt, it goes without saying that assem- 

M 



bly-language programming will also be required. Since this is be- 
yond the scope of this book, we refer you to Programming h- Inter- 
facing the 6502, With Experiments and 6502 Software Design, 
Howard W. Sams & Co., Inc., Indianapolis, IN 46268. Roth books 
discuss the use of interrupts in detail, providing examples and assem- 
bly-language programs for the control of interrupts. 

The Apple interrupts IRQ and NMI use specific memory locations 
from which the 6502 processor "fetches" the address of the subrou- 
tine that is to be used as the service routine for each interrupt. The 
IRQ vises locations FFFEH and FFFFH, and the NMI uses locations 
FFFAH and FFFBH. Since these locations are actually within the 
read-only memory chips that contain the BASIC interpreter and the 
monitor, the addresses in these four locations are fixed and you can- 
not change them. However, these fixed addresses are simply used to 
point to other locations in read/ write memory where you can ac- 
tually change the pointers for the interrupt service subroutines. We 
refer you to the A-pple U Reference Manual for the details of how to 
use these "vector" locations. 

FINAL WORDS 

A few final words are necessary before you leave this chapter. We 
have chosen to introduce you to a simple assembly-language subrou- 
tine for performing the logical and or or manipulation on two 8-bit 
bytes, along with the use of the assembly-language subroutine call- 
ing operation, USR. Actually, the Apple computer has a flag-check- 
ing command in its instruction set: WAIT. This instruction can be 
used to check individual flags, or groups of flags, and it can detect 
logic one and logic zero flags, too. However, there is a limitation to 
its use. If the proper flag pattern is not detected, then there is no way 
for you to ever leave the flag-checking operation, and you must reset 
the computer to get back control. Likewise, you cannot decide to 
branch to one portion of a program if the flag or flags are set, and to 
branch in another direction if they are not set. If the WAIT com- 
mand is used, you will simply continue to WAIT until the condition 
is met. This is fairly inflexible, and we have chosen to avoid the use 
of the W.AIT command for this purpose. 

We have introduced you to the USR command for calling assem- 
bly-language subroutines, and if you expand your horizons and con- 
tinue to learn more about assembly-language programming, you will 
find that this instruction is quite valuable. However, if you simply 
want to access an assembly-language subroutine, such as the logical 
AND subroutine, you can use the CALL command, followed by the 
decimal address of the start of the subroutine. A CALL 771 opera- 
tion can be used to call the logical and subroutine. Of course, you 



must POKE the MASK and DATA bytes before you call the subrou- 
tine. 

The object here has been to show you a bit more of the power of 
the Apple computer and how it can handle different tasks. The easy 
path isn't often the most interesting or educationaL 




CHAPTER 



Breadboarding 
With the Apple 



It has always been our philosophy that computers should be easy 
to use, both for program development and for hardware or interface 
development. Since the necessary signals for interfacing most com- 
puters are readily available somewhere in the computer system, it 
was decided to develop some general-purpose interface circuits that 
could be used with a number of different computers. These circuits 
are fairly simple and are easily constructed and adapted to many 
computers besides the Apple. A printed circuit was developed con- 
taining all of the necessary circuits for interfacing purposes. A photo- 
graph of the interface is shown in Fig. 5-1. A standard 40-conductor 
fiat cable is used to connect the interface breadboard to various com- 
puters. While the interfacing circuits could have been breadboarded 
and then used for the experiments, it was thought that this would 
only provide additional points at which problems could surface. 

BASIC BREADBOARD 

The basic breadboard contains a number of useful circuits that al- 
low interface designs to be easily set up and tested. The basic sec- 
tions are Power Supply, Logic Probe, Device and Memory Decoders, 
Bus Buffers, and Control Circuitry. 

Power Supply 

The power supply section of the breadboard may be operated in 
one of two ways. An external -l-5-volt power supply may be used, as 




Fig. 5-1 . AppU breadboard lystcm. 

long as it can supply 1 ampere of current, or an external transformer 
may be used to supply 12.6 volts (ac) to the on-board power supply 
circuits. In either case, the breadboard power supply is separate 
from the computer power .supply. A separate power supply is often 
used because some computer systems cannot supply sufficient power 
for their own circuits and the added interface circuits that you may 
wish to test. Whenever an external power supply is used, you must 
he sure that there is a good, low-resistance common ground connec- 
tion between both power supplies. A power supply schematic is 
shown in Fig. 5-2. 

If the on-board power supply is to be used, the 12.6-V ac trans- 
former is connected to pins 1 and 2 on plug number 1 ( PI ) ; the rec- 
tifier diodes, DI-D4, the filter capacitor, Cl, and the voltage regula- 
tor, VR, are all installed. We sugge.st that a small heat sink be used 
with the 4-5-volt regulator. When the breadboard is used in this 
manner, +5 volts are available at pin 5, and ground is available at 
pin 6, on PL These connections may be used for external devices, if 
required. 

If a separate -l-5-volt power supply is to be used, the power supply 
parts D1-D4, Cl, and VR are not needed and .should be removed or 
not installed. The -l-5-voIt and ground connections are made at pins 
5 and 6, respectively, at PI. 

Since other voltages are often required, such as ±12 or ±15 volts, 
provision has been made at PI to connect additional external power 
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Fig. 5-2. Breadboard power-supply circuit ichematic. 



supplies. The positive voltage, +V, and negative voltage, —V, are 
connected to pins 4 and 3, respectively, at PI, 

All of the voltages are available at the socket at position IC-16. 
The available connections are shown in Table 5-1. 



Table 5-1. Power Supply Connections for the Power Socket, IC-16 



Pin* 


Voltage Available 


7,10 


+ 5 


5,12 


GND 


3,14 


+ V (External) 


1,16 


-V (External) 


*AtJ othef pins are unconnected- 



Povi'er for the integrated circuits on the printed-circuit board ha.s 
been derived from the +5-volt power supply. The connections at 
IC-16 (socket) provide a means of easily obtaining power for the 
experiments. 

Logic Probe 

The logic probe circuit, Fig. 5-3, is useful in determining the logic 
state of various outputs, and also for detecting pulse activity at out- 
puts. The logic-probe section of the breadboard contains a level de- 
tector and a pulse detector circuit. An LM-319 (IC-15) comparator 
has been used to detect the logic one and logic zero levels, while an 
SN74LS123 (lC-14) has been used to detect and "stietch" pulses. 
We have used a green light-emitting diode ( LED ) for the logic zero 
indicator (D-7), a red LED for the logic one indicator (D-6) and a 
yellow LED for the pulse indicator (D-5). The input to the probe 
is available at pins 1-4 at IC socket IC-19. These inputs are marked 
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"P." All of these inputs are in parallel, and any one may be used, but 
do not try and connect the logic probe to two signals at the same 
time. The logic probe should be thought of as two low-power Schot- 
tky (LS) input loads. 



PROBE P 
IC-19 SOCKET, PINS 




SN74LSI23 
lC-14 

3.3 uf CT 

Fig. S-3. Logic proba circuit scheitMfic. 



If you have an external logic probe, the circuitry in this section 
may not be needed. If you wi.sh, you do not have to construct this 
portion of the circuit. In any case, it will be useful to be able to detect 
pulses and also to be able to detect the state of pulses, etc. We have 
found the logic probe to be very useful in troubleshooting bread- 
boarded interface circuits. 

Memory and Device Decoders 

A major portion of the circuitry on the breadboard is devoted to 
I/O address decoding, as shown in Fig. 5-4. The decoders can be 
operated in either a device mode or a memory mode, depending 
upon the type of computer in use. In device addressing, only the LO 
address bits ( A7-A0 ) are decoded, while in memory addressing, all 
of the address bits ( A15-A0) are decoded. The Apple computer uses 
memory addressing to identify I/O devices, since it is based upon 
the 6502 microprocessor chip. Likewise, computers based upon the 
6800 microprocessor also use memory addressing. Computers built 
around the 8080, 8085, and Z-80 family of chips can use either type 
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IC-19 (SOCKET) 
Fi0. 5-4, Address decoder circuit schematic. 
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of addressing. As you look over the schematic in Fig, 5-4, you should 
recognize that the address decoding uses a combination of digital 
comparators and decoders. 

In the device addressing mode, an SN74LS85 4-bit comparator 
(IC-5) is used to compare preset address bits to the address bits 
present on the LO address bus lines A7-A4. The switches at IC-6 are 
used to preset the logic levels that will be compared with the address 
bus. The package at IC-6 is a set of dual-in-line switches, so care is 
required in making the switch settings. The switch positions are 
clearly marked, "7," "6 " "5," and "4" at the switch marked "LO." If 
you are installing the switch, be sure that the open or off position is 
to the right ( logic one position ) . Pull-up resistors at IC-7 provide the 
logic one inputs to the SN74LS85 when the switches are open, or in 
the logic one position. 

When an address match occurs between the preset bits and ad- 
dress bits A7-A4, the SN74154 decoder (IC-12) is enabled. Although 
the SN74154 decoder has the ability to decode address bits A3-A0 
into 16 unique address outputs, only the first b have been used, 
more than enough for breadboarding and interface testing. 

Thus, if the address switches for bits 7-4 are set to 1011, the de- 
coder would decode addresses IOIIOOOO2 through IOIIOIII2, or ad- 
dresses 176 through 183, decimal. For device addressing, the lowest 
switch at IC-6 must be "open" or in the "D" position. This places the 
decoder in the correct mode. 

The decoded-address outputs arc present at the IC-20 socket. They 
arc labeled "0," "1," and so on, through "7." The entire section is 
called "ADDRESS." Note that there is a bar over the address num- 
bers to indicate that the unicjue output state is a logic zero pulse. 
The address notation, zero through seven, is a sequential addressing 
that will help you in determining which pins are connected to the 
device address outputs. In most cases, the numbers will ham no rela- 
tionship to the actual addresses that have been decoded. In the ad- 
dressing example cited previously, in which addresses 176 through 
183 were decoded, the output labeled "0" would correspond to the 
decoded address of 176. Table 5-2 details the decoder outputs that 
are available at the address socket, IC-20. 

Memory addresses are also ea.sy to decode on the interface bread- 
b;;ard. Two additional comparator chips, lC-3 and IC-4, are used to 
compare address-bus lines AI5-A8 with a preset HI address. The HI 
address bits are set at the eight-switch dual-in-line package of 
switches labeled HI, at IC-2. When using memory addressing, you 
must be careful not to try and select addresses that have been as- 
signed to the internal Apple memory (ROM or R/W). You must also 
remember to convert the complete 16-bit address into the equivalent 
decimal value for use in PEEK and POKE instructions. 
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In the memory address mode, you must place the lowest switch at 
IC-6 in the "closed" or in the "M" position. This allows the SN74154 
decoder to be activated only when there is a match between address 
bits A15-A8 and the bits preset at the HI dip-switch and a match 
between address bits A7-A4 and the bits preset at the LO dip-switch. 
Thus, addresses between XXXXXXXX XXXXOOOO and XXXXXXXX 
XXXXOIII are accessible, where X=l or 0. These decoded addresses 
are present as logic zero pulses at the "ADDRESS" socket (IC-20). 
Remember that only the first eight addresses in a selected 16-address 
block are available. Thus, if 10000001 is set for the HI address and 
1110 is set for the LO address (bits A7-A4), addresses 33248 through 
33256 would generate logic zero pulses at pins 1 through 8 at the 
"ADDRESS" socket, respectively. Keep in mind that the SN74154 
decoder decodes all 16 addresses; you only have access to the "lower" 
eight. 



Table 5-2. Addrsss-Dscoder Connections for the Addresi Socket, IC-20 



Pin (IC-20) 


Designation 


SN741S4 Output Pin 


1,16 





1 


2,15 


1 


2 


3,14 


2 


3 


4,13 


3 


4 


5,12 


4 


5 


6,11 


5 


6 


7,10 


6 


7 


8,9 


7 


8 



Connections for address-bus lines A3-A0 (unbuffered) are avail- 
able on the breadboard at pins 8-5, respectively, on the socket at 
IC-19. These signals may be used in some experiments, but caution 
is required, since these signals are not buffered, and present a direct 
connection to the Apple computer. 

The address decoder section of the breadboard will save you a 
great deal of time and effort, because you will not have to construct 
device address decoder circuits when you wish to implement I/O 
ports, or try some simple interface circuits. 

Bus Buffers 

Two 8216 noninverting bus buffer chips, IC-10 and IC-11, have 
been used to buffer the bus, as shown in Fig. 5-5. This means that the 
bus is available with a full fan-out of 30 (it can power 30 standard 
7400-type inputs) and that it is isolated from the Apple data bus. 
The eight bits on the data bus are available at the socket at IC-18. 

The information in Table 5-3 shows the connections to the data 
bus. 
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Fig. 5-5. Bin buffer circuit ichematic. 



The bus buffers are always enabled, and the normal mode of op- 
eration is for the transfer of data from the Apple to the breadboard. 
This means that without additional signal use, you could monitor the 
bus "activity" by connecting logic probes or other suitable monitors 
to the outputs of the bus buffer chips, D7-D0. Output ports are im- 
plemented by simply using the proper control signals ( described in 
the next section) to control an 8-bit latch. The eight latch inputs are 
connected to D7-D0 at the socket IC-18, 

Input ports, however, must be implemented so that they turn the 
bus buffers in the opposite direction to "drive" data into the Apple. 
Actually, there are two bus buffers for each bus line, as shown in the 
pin configuration shown in Fig. 5-6 for the 8216 buffer. The DIEN 
input determines which set of buffers is enabled, thus directing data 
to, or from, the Apple. All input operations must activate the proper 



ToUa 5-3. Dots Bui Connections ol IC-1B 



Pin (IC-1S) 


Data Bus Signal 


1,16 


D7 


2,15 


D6 


3,14 


D5 


4,13 


D4 


5,12 




6,11 


02 


7,10 


Dl 


8,9 


DO 
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Fig. S-6. Tha 8216 bus buffer chip pin configuration. 

set of buffers so that the Apple receives the data properly. Special 
control circuitry has been provided to do this for input operations. 

Control Circuitry 

The control circuitry on the breadboard is rather simple, consisting 
mainly of some general-purpose buffers to buffer control signals out- 
put by the computer. Six signals are provided, IN, RD, OUT, WR, 
RESET, and IN TAK . For Ap ple inter facing, you will only be con- 
cerned with the WR, HD, and RESET signals. The other signals are 
useful when the breadboard is used with other computers. This con- 
trol circuitry is shown in Fig. 5-7. The general-purpose interrupt sig- 
nal is also buffered, but it is an input to the computer. Connections 
to the control signals are made at the socket at IC-17, as noted in 
Table 5-4. 

The control circuitry also generates a signal that switches the 8216 
bus buffers into the input mode, so that data may be transferred into 
the Apple. It would seem to be merely a matter of turning the bus 
around whenever a memory read operation took place. If this were 
implemented, the bus buffers on the breadboard would be placed in 
the input mode, even when a memory chip was activated within the 
Apple. This would cause a bus "conflict," so the bus on the bread- 
board must be placed in the input mode only when an input device 
on the breadboard itself has been selected. 
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To handle input ports properly, the input port device select signal 
is used to gate data onto the data bus and also to control the mode 
of the 8216 bus buffers. In effect, up to four input port device select 
pulses may be ORed together to place the breadboard bus buffers in 
the input mode. You will probably not use more than four input ports 

+ 5 



21 
IS 
14 
13 
12 
19 
2 




IC-17 SOCKET 

—in 



,15 1 


10 


,14 t 


12 


.13 1 


13 



SN74LS2Q 



ENABLE 



Fig. 5-7. Control circuit Khematic. 



on the breadboard. Thus, these signals turn the bus around for the 
input o£ data only when an input port device select signal is gener- 
ated on the breadboard, and it is wired by the user to one of the four 
bus buffer enable inputs. 

The "INPUT REQUEST" control pulses are required to be logic 
zero pulses. They are applied to the pins labeled W, X, Y, and Z, 
which are pins 16 through 13 on the socket at lC-17. 



Table 5-4. Control Signal Connections at IC-I? 



Pin (IC.17) 


Control Signal 


Direction 


i 


TFrf 


Input 


2 


Not Used 




3 


INTAK 


Output 


4 


RD 


Output 


5 


OUT 


Output 


6 


WR 


Output 


7 


RESET 


Output 


S 


IN 


Output 
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The actual ORing of these control signals is performed by the 
SN74LS20 gate, IC-8. The INPUT REQUEST signal that is output 
by this 4- input nand gate is further gated with OUT and VVR. This 
gating provides a safety interlock, so that if your breadboard circuits 
have been improperly wired, the bus drivers cannot be placed in the 
input mode when an output-type operati on is taki ng pl ace. The re- 
sultant "INPUT REQUEST, BUT NOT OUT OR WH" signal con- 
trols the input/output mode of the 8216 bus buffers. 

Since the Apple generates only the memory write signal, WR, this 
simply means that your interface will not be able to turn the bus 
around for an input operat ion, when the computer is performing a 
write operation. The OUT signal is used for interfacing with 8080, 
8085, or Z-80 computers. 

Two input ports are shown in Fig. 5-8. Each of these ports is con- 
trolled by a device select pulse that enables the three-state buffers. 
This same signal is used as the input request signal, INP REQ, and 
each input port mu.st generate its own input request signal. In this 
example, the two input request signals have been connected to the 
W and Z pins at the INP REQ section of the socket at IC-17. It 
would have been just as easy to connect the lines to the X and Y pins. 

The use of the interlocking INPUT REQUEST signal, and the as- 
sociated circuitry only applies to testing interface circuits on the 
breadboard. If you wish to construct an interface that will directly 
plug into the Apple, and that will not use bidirectional bus buffering, 
then you will not need to use such an interlock. The main purpose of 
this circuitry is to protect your Apple computer from possible dam- 
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Fig. 5-8. Typical inpul ports showing use of INPUT REQUEST signal. 
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Fig. 5-9. Wir«-wrap vanion of Ih* interface circuit. 



age caused by careless or incorrect wiring of a test circuit, Once a 
circuit has been completely tested and debugged, you can probably 
connect it directly to the data bus of the Apple without any problem. 

Breadboard Construction 

The breadboard circuits may be constructed using wire-wrap tech- 
niques, as shown in Fig. 5-9. In this case, the circuits could be ex- 
panded and modified through simple wiring changes, but the bread- 
board itself would be somewhat difScult to use. 

To aid in interface construction and testing, a printed circuit has 
been developed in which all of the neces.sary circuitry has been 
placed on a single board. The power supply and logic probe circuitry 
have been incorporated to make the breadboard easy to use. The 
breadboard is shown in Fig. 5-10, and is available in kit or assembled 
form from Group Technology, P.O. Box 87B, Check, VA 24072. A 
large space has been left unused on the breadboard so that a solder- 
less breadboard socket may be mounted directly on the printed-cir- 
cuit board for easy experimentation. Typical breadboard sockets are 
the "SK-10" from E & L Instruments, Derby CT 06418 and the "Super 
Strip" from AP Products, Inc., Mentor, OH 44060. A complete list of 
parts needed for the breadboard, along with the printed-circuit board 
artwork is provided in the Appendix. 

CONNECTIONS TO THE APPLE 

Since the interface breadboard uses a 40-conductor cable to con- 
nect to various computers, you will need a means of connecting the 

so 



Fic|- 5-10. Packaged version of the interface. 



cable to one of the peripheral interface slots in the Apple. We rec- 
ommend the use of a flat cable assembly such as shown in Fig. 5-11. 
There is a printed circuit female edge connector assembly on one end 
of the cable, and a 0.1-inch by 0,1-inch female pin grid connector 
on the other. The openings on both connectors must face in the same 
direction. A ready made cable is available from Group Technology, 
BG-lOO-Cable, which uses a two-foot length of flat cable. 

The actual connections with the Apple bus signals are made with 
a small adapter card. This card "twists" and "turns" the various sig- 
nals so that they are routed from the edge connector to the periph- 
eral connector in the Apple. You can easily put together an adapter 
by using a Vector 4609 prototype card. This card plugs into one of 



PC BOARD EDGE 




EDGE CONNECTOR 




PIN CONTACTS 



0.1- GRID 
CONNECTOR 



CABLE APPROX. Z FT. 



Fig. 5-11. Cable for interface. 
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F!g. 5-12. Apple-ta-lnterface 



the peripheral connectors in the Apple, and it has a 40-conductor 
edge connector that will connect directly to the interface cable. Of 
course, if you wish, you may make direct solder connections to the 
cable, but we do not recommend this. You can malce direct soldered 
connections between the corresponding signal conductors on each 
edge connector by using short pieces of hookup wire. If you do not 
wish to make soldered connections, you can solder wire-wrap pins 
into the holes provided at each edge connector, making the connec- 
tions using wire-wrap wire. 

The connections are shown in Fig. 5-12. If you choose to use the 
Vector prototype card, there are several important things that you 
must do before you start to make the connections between the two 
edge connectors, no matter which wiring technique you choose to 
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use. There are probably one or two printed circuit "foil runs," or con- 
ductor paths between the 40- conductor connector and the +5-volt 
and ground contact pins on the 50-conductor Apple connector. All 
such connections must be broken, so that the 40-conductor connector 
contacts are "free," and uncommitted to any signals. You can use a 
small razor knife to cut these connectors. We recommend making 
two cuts through each conductor, about 2 or 3 millimeters apart. A 
soldering iron can then be used to "lift" the cutout section by heat- 
ing it. You should do this to only the power connections which are 
coimected between the two connectors. All of the other pins are 
tree. 

Since the Vector prototype board does not use plated-through 
holes, be sure that you connect +5 volts and ground to the respective 
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power buses, and that the proper connections are made to the 
SN7400 chip, 

The SN7400 chip is used to gate the read/write (R/W) signal with 
the main clock signal of the 6502 processor, <J>1. This gating g enera tes 
the memory read signal, RD, and the memory write signal, WR. If 
this gating is not done, the computer peripherals on the interface 
breadboard will not work properly. In some computers, there are 
separate read and write signals. If you wish to use separate read and 
write signals for memory control in the Apple and other computer 
systems that are based on the 6502 microprocessor chip, you must 
generate them through the proper gating. 
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F!g, 5-13, Vector 4609 card contacis and intarfac* contact arrangements. 



The pin locations for the Vector card edge connectors are shown 
in Fig. 5-13. Please note that this figure shows the component side 
of the card. Once you have made the needed connections between 
the two edge connectors, and between the connectors and the 
SN7400, we suggest that you use an ohmmeter or other continuity- 
checking instrument, to be sure that there are no short circuits be- 
tween adjacent and opposite pins, and that the correct connections 
have been made. These tests should be made with the SN7400 chip 
out of its socket. However, don't forget to plug it back in after you 
have tested the connections! 



OTHER CONSIDERATIONS 

If you wish to try and interface some of the 6502 family interface 
chips, and even some of the nonfamily chips, you will find that these 
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chips have rather slow access times when compared to the standard 
three-state input chips, such as the SN74365 and the SN74LS244. 
Access times for these large, programmable chips can be as long as 
200 ns. Since the read/ write timing for the 6502 chip is fairly critical, 
there will not be sufficient time for the data from these chips to be 
accessed and placed on the bus if the extra delay caused by the 8216 
bus bufEer chips and the interlocking circuits is taken into account. 
Therefore, if you wish to use the breadboard to test interface circuits 
that use complex, programmable interface chips, you will need to 
"defeat" the interlock. You can do this rather simply by removing the 
two 8216 bus buffer chips and by using short jumper wires at each 
socket to connect the Apple data bus signals to the interface data bus 
lines. For example, you would need a jumper between pins 5 and 6, 
pins 2 and 3, pins 14 and 13, and pins 9 and 10 on each socket. We 
refer you to Fig. 5-5 for the circuit that uses the 8216 bus buffer chips. 

A word of caution is in order, however. By removing the bus buf- 
fer chips, you are connecting your interface circuits directly onto the 
Apple data bus. Please use extreme caution when doing this so that 
you do not cause any short circuits or bus conflicts in the Apple. We 
have provided a simple interface example in Chapter 7 in which the 
direct bus interfacing is used. 
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CHAPTER 



Apple Interface 
Experiments 

The purpose of the experiments in this section is to provide you 
with some hands-on experience in the use of latched output port and 
three-state input port circuits that were developed in the previous 
chapters. You will find that these experiments use simple SN7400- 
series devices to transfer data to and from the Apple. 

INTRODUCTION TO THE EXPERIMENTS 

Breadboarding of circuits will be required in this chapter, and a 
complete list of parts that will be used is provided in Appendix B. 
We have assumed that you have had some experience in breadboard- 
ing simple logic circuits, and that you are familiar with the basic 
breadboarding skills. Some auxiliary fimctions will be required in 
the experiments to both monitor logic states and to generate them. 
In general, we use lamp monitors or LEDs to indicate logic one (on) 
and logic zero (off), logic switches to generate logic levels, and de- 
bounced pulsers, or pulsers for short, to generate logic levels with 
clean noise-free transitions between the logic levels. Some simple 
schematic diagrams of these types of circuits are provided in the 
Appendix. If you do not wish to build these circuits, they can be 
breadboarded separately, or similar functions can be purchased from 
companies such as E & L Instruments, Derby, CT 06418 or P AC- 
COM, Redmond, WA 98052, In general, most of the experiments in 
this book can be done with a few simple circuits. 

We have provided one experiment that illustrates the use of a 
decoder circuit for device addressing. While many decoder schemes 
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are possible, we think that one experiment should illustrate the basic 
principles. If you are interested in other decoder circuits, there are 
many different ones described in 8085 A Cookbook, and Program- 
ming if Interfacing the 6502, With Experiments ( Howard W. Sams 
& Co., Inc., Indianapolis, IN 46268). Actually, memory and I/O de- 
vice addressing is pretty much the same, from one computer to the 
next In most interface circuits, the decoder circuit that is used on 
die interface breadboard will work quite well. 

While this book tackles Apple interfacing at a fairly low level, 
there are other important interfacing topics that you might wish to 
study. Many of these aw covereS fti TkS-^O^ Interfacing, Book 2 
'Howard W. Sams & Co., Inc., Indianapolis, IN 46268). The infor- 
mation presented is fairly general, and it is easily applied to Apple 
compufaH- ^istems. TtJjacs c^^wr^ ineliidet Mi^-current, hlgh-i^eSt- 
age load driving, digital-to-analog and analog-to-digital converters, 
practical data processing (smoothijig, filtering, averaging, etc.), 
serial communicatiofls, and remote eotttol. 

The photograph in Fig. 6-1 shows a typical Apple-breadboai-d lab- 
oratory station that is used in performing the experiments in this 
chapter. A 40-conductor has been used to connect the bread- 

board and the Apple computer— Fig. 6-2. This cable has been de- 
scribed ill Chapter 5. When you connect the interface breadboard 
to the Apple, be sure that the cable is oriented properly. The cable 
must point away from the component side of the card used to con- 
nect the interface to the Apple. At the interface-breadboard end of 




Fig. 6-1 . Apple computer and biesdbaard in experimental um. 
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Fig. 6-3. Interfacs cabl*. (Not« c«nn«cter efisntati«n on »niB side of flat cabla.) 



the cable, the cable must be pushed onto the 40 pins so that the cable 
is poijited either down or away from the printed-circuit board. If the 
cable is connected improperly, the Apple will respond with a screen 
full of random characters rather than the APPLE II banner, when 
it is first turned on. This does not seem to cause any permanent dam- 
age to the Apple or to the interface as long as they are not connected 
this way for too long. 

Some experiments will build On, or use, the circuits or programs 
developed in previous experiments. Please do not turn ofE the power 
to the computer, and do not disconnect circuits imtil you are told to 
do so, otherwise, you will spend a great deal of time reloading pro- 
grams and reconstructing interface circuits. There will be a reminder 
at the end of some of the experiments just so that you don't forget 
this tip. 

Most readers will probably perform the experiments in sequence, 
so there will not be too much difficulty in referring back to previous 
experiments for the details of the interface circuits. However, if you 
choo.se to skip over some experiments you may find this a bit confus- 
ing. To help everyone with the interface circuits, we have repro- 
duced the important input port, output port, and control circuits in 
Fig. 6-27 at the end of this chapter. You can make a photocopy of 
this figure, or you may remove it from the book so that it will be 
nearby when you need it. The basic circuits shown in this figure are 



used in most of the experiments unless otherwise noted, and you can 
use these circuits to build general-purpose input and output ports as 
you need them. 

If you are an instructor planning to use this book as the basis for 
laboratory experiments with the Apple, you will find that the pro- 
grams are easily loaded onto cassettes. In this way the programs are 
readily available for the students, who do not have to spend their 
time trying to debug programs. If you choose to use cassettes, you 
should use high quality tape, and once the programs have been re- 
corded on the tape, the "write protect" tab on the back edge of the 
cassette should be removed. This will prevent students from acciden- 
tally recording programs over those already on tape. 

Students may find it valuable to maintain cassettes of their ovra, 
so that their lab solutions and other programs are readily available, 
either for exchange with other students or lab groups, or for refer- 
ence during the next lab period. 

The experiments in this chapter have been divided into two 
groups, although no division, chapter subheading, or other note 
marks the sections. The first 11 experiments provide a ba,sic set of in- 
terfacing and programming investigations for readers who are inter- 
ested in basic interfacing concepts. These first experiments provide 
a basis for the laboratory portion of a first course in computer Inter- 
facing and computer electronics. 

The last few experiments provide additional lab investigations into 
more advanced topics, and they also provide projects that may be 
used to supplement the basic set of experiments. Of course, all of the 
experiments may be done, too. 

EXPERIMENT NO. 1 
USE OF THE LOGIC PROBE 

Purpose 

The puq)0se of this experiment is to show you how the logic probe 
circuit on the breadboard may be used to detect logic levels and 
pulses. 

Discussign 

We have assumed that you are using the breadboard logic probe, 
although other logic-probe circuits will work equally well. The steps 
in this experiment are useful in helping you to become familiar with 
the breadboard and the signals available. 

Step 1 

Your Apple computer should be connected to its video monitor 
and also to the interface breadboard through the 40-conductor cable. 



This connection has been described in the introduction to the experi- 
ments. 

Turn on the power to the Apple and to the breadboard. The com- 
puter should print "APPLE II" and the flashing square cursor should 
be seen. If this is not the case, turn off the power and check your con- 
nections. Be sure that the 40-conductor cable is securely pushed onto 
the pins at the interface breadboard and onto the edge of the board 
that connects it to the Apple. You should also check the orientation 
of the cable to be sure that it is correct. If you cannot locate the prob- 
lem, obtain as.sistance. 

Step 2 

With the power applied to the breadboard, connect a jumper wire 
between one of the logic probe input pins, P, at the PROBE socket, 
and one of the +5-volt power pins at the power socket. What is the 
effect on the logic probe indicators? 



The red LED is on, indicating the presence of the logic one state. 

The probe jumper wire should now be moved from the -|-5-volt 
power pin to one of the ground pins on the same power socket. What 
is observed, once this connection is made? 



The green LED is on, indicating the presence of a logic zero state at 
the input to the probe circuit. You may have noticed that the pulse 
detecting LED (yellow) flashed as you made the connection to +5 
volts or to ground. This flash indicates that the probe detected a 
change in the logic level. Either a logic-one-to-logic-zero, or a logic- 
zero-to-logic-one transition will cause the yellow LED to flash. This 
makes it particularly useful for detecting pulses and logic transitions. 

Connect the probe input to address line AO at IC-19. What do you 
observe when this connection has been made? All of the LEDs are 
on, probably at different intensities. This is due to the fact that the 
6502 microprocessor chip is executing many, many assembly-lan- 
guage instructions in the BASIC and monitor ROMs, thus u.sing the 
address bus to address various memory locations. Move the logic 
probe test wire to the other address bus lines, AI, A2, and A3. You 
should be able to detect similar "activity" at these pins, too. 
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Step 3 

You may wish to test other points on the breadboard with the logic 
I probe. The data bus lines and the control signals may be easily 
tested. You should keep in mind that the logic probe is only sensitive 
to the logic levels presented by the outputs of standard transistor- 
transistor logic ( TTL ) chips used on the breadboard and in the ex- 
periments. Do not attempt to use the probe to measure anything but 
these logic levels. If you connect the probe to voltages outside the 
zero to +5-volt range, the probe circuit will be damaged. 

Step 4 

When you use the probe, you will notice that there are many com- 
binations of lit LEDs. For example, you may see that the red and 
yellow LEDs are lit, while the green one is unlit. Do you have an 
idea of what this means? 



This means that a pulse is being detected, and that the normal logic 
level of the circuit being tested is a logic one. The green LED light.s 
very briefly (you can't see it), to indicate the fleeting presence of the 
logic zero pulse. The pulse detecting circuit stretches the pulse and 
hghts the yellow LED so that you can "see" that a pulse has been 
"caught." 

You may also see the green and yellow LEDs on, with the red 
LED off. What would this indicate? 



A logic zero level would be indicated, with short logic one pulses. 

It is possible that all LEDs may be lit, too. In this case, the input 
to the logic probe is rapidly changing between logic one and logic 
zero. 

In some of the following experiments, the logic probe will be used 
to examine outputs and to detect logic states and pulses. This will 
be noted by, . . use your probe to examine. . . ," or perhaps by, 

. . use the logic probe to measure . . . This simply means that you 
are to connect the logic probe to the circuit being tested, so that you 
can "see" what is happening. 

Tm-n your computer off. 



EXPERIMENT NO 2 
USE OF THE DEVICE ADDRESS DECODER 

Purpose 

This experiment allows you to explore the use of the device ad- 
dress decoder circuit on the interface breadboard printed-circuit 
board. Since this decoder will be used in all of the experiments, you 
must have a good understanding of its use. 

Discussion 

In this experiment, address bits A15-A0 will be used to identify 
specific addresses for use by I/O devices. The address switches will 
be set up for a specific range of addresses, and the logic probe will 
be used to examine the action of the decoder circuit. You will also 
use an SN7402 noh gate integrated circuit. 

Pin Configuration of the Integrated Circuit (Fig. 6^) 

4B 4A 3V 



VCC 4Y w «A 3V 3B JA 




Fig. 6-3. SN7402 NOR-gate pin configuratign. 



W lA 1B 2r 2A 2& GHO 

SN7402 

Step 1 

No circuits should be presently wired on your breadboard. If there 
are any circuits present, remove them from the solder less bread- 
board. In this experiment, the entire 16-bit address bus will be used 
by the decoder section of the interface. Be sure that the bottom 
switch at the LO address dip switch (IC-6) is in the "M" position, 
or in the "ON" position. 

Step 2 

Place the dip switches for all of the address bits, A15-A4, in the 
logic one position. Remember not to change the setting of the "M" 
switch. Can you determine which set of addresses will be decoded 
by the SN74154 decoder? What addresses in this block will be avail- 
able at the ADDRESS output socket? You may wish to examine the 
schematic in Fig. 5-4. 
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Addresses in the block from 65520 to 65535 will be decoded by the 
4-to-16 decoder (SN74154). Since the decoder only provides you 
with the 'Tsottom" eight addresses, only addresses from 65520 to 
65527 will be available. 

Step 3 

Turn your computer on. If you are running a program, press the 
RESET key. Use the logic probe to test the eight address outputs at 
the ADDRESS socket. Are any of the decoder outputs active (puls- 
ing)? Since you are not running a program, is this what you would 
expect? 



Two of the outputs should be active, and 4, corresponding to 
addresses 65520 and 65524. While the computer is not running a 
BASIC program, it is executing many assembly-language steps that 
monitor the keyboard, etc. Remember that the address decoding cir- 
cuitry is ahmys decoding addresses. 

Step 4 

Wire the circuit shown in Fig. 6-4. Be sure that you connect the 
power pin, pin 14, to -f-5 volts and the ground pin, pin 7, to power 



RD 
7* 



SN?40Z(ALL) 



•DECOOEfi SOCKET POSITIONS 
Fig. 6-4. Function pulse-ganantion circuit. 



ground. Refer to Fig. 6-3 for the pin configuration of the SN7402. 
You may substitute an SN74LS02 for this chip. The outputs of the 
gates, A, B, and C, are not connected to any circuit at this time. 

Step 5 

Change the switch settings on the dip switches for bits A15-A4 for 
an address of 49312. This is 11000000 lOlOOOOOj, and you should ig- 
nore the four least-significant bits. What range of addresses will be 
available when the address switches are set this way? 
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Addresses from 49312 through 49327 will be decoded, but only ad- 
dresses 49312 through 49319 will be available. 

Step 6 

Enter the following program into the computer and run it: 

10 A = peEK(493T8) 
20 GOTO JO 

Using the logic probe, monitor the outputs of the decoder, and note 
your observations below: 



You should see that the "6" output is active, and one or more other 
outputs may be active, too. 

Now monitor the outputs of the gates, A, B, and C, and note any 
activity, at these points, as determined with the logic probe, in the 
space below: 

Logic Logic I Pulse 

A 
B 
C 

Is this what you would expect? Can you explain this? 



Yes, this is what is expected, since the input (PEEK) command is 
the program specified device 49318 as an input device, and the de- 
coded address is found at the "6" output from the decoder. Thus, only 
output "B" should be active. No other input devices were specified 
in the program, and no output devices were specified, either. 

Step 7 

Change the device address in line 10 so that address 49325 is se- 
lected. Line 10 should now be 10 A=PEEK{ 49325). Run the pro- 
gram and test the gate outputs A, B, and C once again. Are any of 
the outputs active, indicating the presence of pulses? Why? 

M 



None of the outputs should be active, since device address 49325 has 
not been implemented in the circuit. Furthermore, address 49325 is 
not readily available on the breadboard. Of the addresses in the 
block 49312 through 49327, only addresses 49312 through 49319 are 
available at the ADDRESS socket. 

Step 8 

Change line 10 in the program so that it is now 

10 A=PEEK(49318):B = PEEK(49319) 

Where do you observe the pulses in the circuit when you run the 
modified program? 



You should find that outputs A and B are active. Output C is not ac- 
tive since it is an output control pulse, and there are no output 
(POKE) commands in the program. 

Sfep 9 

Make another modification to your program. Change line 10 so 
that you can control output device 49318. Your statement at line 10 
should look like this: 

10 POKE 49318,0 

You can use any data value that is between and 255, inclusive. Now 
run your program and test outputs A, B, and C. \\Tiich output do you 
expect to be active? Is this what you found? 



Output C is active, since the POKE command is an output-type com- 
mand, and the address, 49318, corre.sponds to the "6" output pin from 
the decoder. You are probably surprised to see that the B output is 
also active. When a POKE instruction is executed by the BASIC in- 
terpreter in the Apple, the computer system does a read-before-write 
operation, so that the selected address is read from, before being 
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written to. This must be kept in mind during the design of interface 
circuits. 

Step 10 

Could you reconfigure the switches in the address decoder section 
so that addresses 50944 through 50951 are generated by the decoder? 
How would you attempt to do this? Are these addresses really going 
to be available? 



Yes, you could change the switch settings to allow the decoder to 
operate between these addresses. First, convert the first address into 
its binary equivalent: 50944 = 11000111 00000000. Second, make the 
changes in the switch settings for A15-A8 and for A7-A4. Now, what 
addresses would correspond to the "6" and "T' outputs from the de- 
coder? Test your answers by using PEEK commands in the simple 
program that you have been using in this experiment. You should be 
able to see the pulses at the A and B outputs from the gates. 

Once you have tested this, be sure to return the address switches to 
their previous settings, corresponding to the binary value, 11000000 
10100000. 

Do not remove the circuit from your breadboard. It will be used 
again. The program will not be used, however, so you may turn off 
the power to your breadboard and computer. 

EXPERIMENT NO. 3 
USING DEVICi-SELECT PULSES 

Purpose 

In this experiment, you will observe the use of device-select pulses 
to control an external device. Although generally used to control the 
flow of information, the PEEK and POKE coirmiands may also be 
used to generate useful pulses to simply control external devices. 

Discussion 

In this experiment, a simple device will be turned on and oflE 
through the use of device select pulses. The logic probe vdll be used 
as the "device," and a simple flip-flop will be controlled by two soft- 
ware-generated pulses. 



Pin Configuration of the Integrated Circuits (Fig. 6-5) 



2 




SN7474 



Fig. 6-5. SN7402 tnd SN7474 <h!p pin conftgurttions. 

Step 1 

The device select circuit used in Experiment No. 2 is also used in 
this experiment If it has not been wired, wire it as shown in Fig. 6-4. 

Step 2 

Wire the SN7474 flip-flop as shown in Fig. 6-6. The "1" noted at 
the "D" input to the SN7474 means that a logic one (-1-5 volts) is 
applied to this input. Likewise, a "0" would indicate a logic zero, or 
ground connection. The and 1 notations are used to distinguish 
logic level connections from power-carrying connections. The Q out- 
put from the flip-flop should be the only device connected to the 
logic probe. Remember to make the power connections to the 
SN7474 flip-flop; pin 14 to -f-5 volts and pin 7 to ground. 

Step 3 

In this circuit, the WR 49318 pulse (signa l C) will clock the out- 
put of the flip-flop to a logic one, while the RD 49319 pulse ( signal 
A ) will clear it to a logic zero. Since a flip-flop is stable in either state, 
once pulsed by RD 49319, its Q output will remain in the logic one 




TO LOGIC PROBE 



SN7474 



(RD 49319) 

Fig. 64. SimpI* flip-flop controllar circuit. 
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st ate until po wer is removed, or until it is cleared to logic zero with 
a WR 49318 pulse. 

Enter the following program in to your computer arid run it. 

10 A = PEEK(493T9) 

20 POKE 49318,0 

30 FOR T = TO 300: NEXT T 

40 A = PEEK(49319) > 

50 FOR T = TO 300: NEXT T 

60 GOTO 20 

Disregard the flashing of the logic probe pulse LED. What is the 
effect on the logic one and logic zero LEDs? 



They flash logic one, logic zero, logic one, etc., in sequence. 
Step 4 

Alter the time delay routine at line 50 to: 

50 FOR T = TO 1000: NEXT T 

When this change has been made, run the program. What is the 
effect of this simple program change? 



The logic zero LED is on for a longer period. Thus, it is possible to 
generate control pulses that are a known period apart, say 1 second. 

Step 5 

Can you determine the software delay necessary in a FOR . . . : 
NEXT T statement to generate a 1-second period? Modify your pro- 
gram and test various delay counts until you closely approximate 1 
second. You might want to try for a 10-second period and then divide 
the count by 10 for a 1-second period. What delay count did you 
come up with? We found that a delay statement, 

FOR T = TO 780: NEXT T 

required about 1 second to be executed. 
Step 6 

You can now use the power of BASIC to allow you to tell the com- 
puter how long each LED is to be ON. The following program may 



n 



feratered and run. It first asks you for the period of each LED, in 
Mconds, and then runs the program. 



lO A = PEEK(49319) 

30 INPUT "RED LED PERIOD ";Q 

30 INPUT " GREEN LED PERIOD "; R 

40 PRINT "TOTAL CYCLE PERIOD "; Q + R; " SECONDS' 

50 POKE 49318,0 

±0 FOR S = 1 TO Q 

70 FOR T = TO 780: NEXT T 

83 NEXT S 

90 A = PEEK(49319) 

100 FOR S = 1 TO R 

110 FOR T = TO 780: NEXT T 

120 NEXT S 

130 GOTO 50 



When the program is run, the time delays may be somewhat length- 
caed. Why? 

I 

Tlie additional software steps ( FOR S = 1 TO Q, FOR S = 1 TO R 
and NEXT S), add time to the overall execution time of the pro- 
gram, although you will not see appreciable lengthening of the pro- 
gram. 

What does this program show you? 



It illustrates many principles; the use of simple programs and simple 
circuits to control external devices. It also illustrates the power of 
BASIC to control external devices through relatively simple software 
steps. Remember, though, that BASIC is relatively slow. 

Even though PEEK and POKE commands were used, the success 
of the flip-flop interface did not depend on the actual transfer of any 
data or information. The flip-flop was controlled, or switched, 
through the use of device select pulses, alone. This principle is often 
used when a control signal or control pulse is required, but no data 
is transferred. 

Please remember that when a POKE command is used in the 
B.ASIC interpreter in the APPLE computer, a read and a write opera- 
tion are performed. Thus, if you choose to use a POKE command to 
generate a device select pulse for control purposes, you must remem- 
ber that the APPLE will also perform a read from the same address. 
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If you are using two control pulses with the same address, say, WR 
ie5fiZ attd HD XYZ, the ED HIS will ate> be ia«3tfmted dti^ittg a w*it0 
operation caused by a POKE XYZ command. 

The SN7474 flip-flop circuit may be removed from your bread- 
board, but the SN7402 ciliSift ilpuld be retained. Hie program 
mt be used agwo, so you f ©mow^e psvper imm ymxt #$tena. 



EXPEMMENT NO. 4 
CC^iTRUCTING AN INPUT PORT 

Purpose 

The purpose of this experiment is to construct an input port using 
•airee-state htMst drfarab. 



Discussion 

Hie s!«^fe#'Wt lifqmt port tot fm will €Mrtm«*as a part rfllii 
experiment will provide a means of entering data into the computer. 
Several additional experiments will use this input port. The device 
select circuit used previously will be used iii this e^jperfment The 
SN74365 or DM8095 three-state buflfer chi[» will be used in tins 
experiment. 

Pin Configuration of the Integrated Circuit (Fig. 6-7) 

vcc Sj tv SA av 4* <v 



ITjl^ $-7. $N74365, or DM8095 tlir«(» 
ritate biHfbr chip pin configuratiwb 



,.$1. IJi;: 1* m ilk » .Die . 

Step T 

The gating circuit developed in Experiment No. 2 will be used in 
iMs experiment. If this circ^^t is not present on your breadboard, 
refer to Fig. 6-4 for the circuit details, and wire the circuit ^OWQ- 
Your computer and breadboard power should be off. 

Step 2 

Wire the 8-bit input port circuit shown in Fig. 6-8. Two SN74365 
(DM8095) three-state integrated cSre?rtls are ts^Mmd- 
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Fig. 6-8, Simple 8-bit input port. 



Step 3 

Note that in this circuit only one of the two enabling inputs to the 
three-state buffer chips has been used. The unused input has been 
grounded, or connected to logic zero. Thus, the internal gate will not 
be used for combining a function pulse and a device address. The 
enabling signal will simply be transferred through the gate to the 
three -state buff er circuits within th e chip. 

Connect the DEVICE SELECT line to point A (pin 1 o n the 
SN7402), as shown in Fig. 6-4. This is the signal for RD 49319. 

The notation LOGIC S WITCHES in Fig. 6-8 is used to represent 
switches that can generate logic one or logic zero signals at the eight 
individual inputs to the input port. Simple jumper wires to the -1-5- 
%'olt and ground power supply buses may be used. There is addi- 
tional information in the Appendix about this type of logic function. 

Step 4 

Once the input port has been constructed and the device select 
pulse has been provided from the SN7402 nor gate, enter and run 
the following test program: 

10 PRINT PE£K(49319}: GOTO 10 



What is displayed on the screen when the program is running? Does 
changing the logic switches have any effect on the displayed value? 
Is this what you would expect? 



The value 255 is displayed, corresponding to IIIIIIII2. Changing 
the logic switches had no effect on the values that were displayed. 
At first, you might have expected the values to change as you 
changed the switch settings, but this was not observed. Why? 



The interface circuit was not provided with an input request ( INP 
REQ) signal that is used to place the two bus buffers in the input 
mode. 

Step 5 

Make a connection between the SN7402 A, or RD 49319, signal and 
the W input at the INP REQ section of the CONTROL SIGNALS 
socket. This signal will place the 8216 bus buffers in the input mode. 

Now that this connection has been made, restart your program and 
change the switch settings. Are the changes in the switch settings 
shown as changes in the numbers being displayed? You should test 
several different settings. 



The switch values are now transferred to the computer, converted 
into decimal numbers and displayed on the monitor screen. 

If you would rather see the values in binary form, the following 
program may be run. It will display the binary numbers continu- 



ously. 




10 


A = 128 


20 


B = PEEK(49319) 


30 


FOR Q = 1 TO 8 


40 


IF B-A<0 THEN GOTO 100 


50 


PRI^T "1"; 


60 


B = B-A 


65 


A = A/2 


70 


NEXT Q 


75 


PRINT 


80 


GOTO 10 



102 



100 PRINT "0"; 
110 GOTO 65 

If you wish to change a switch setting and then obtain its binary 
equivalent, change line 10 to; 

10 INPUT A$: HOME: A = 128 

Now, whenever you wish to display the binary value of the logic 
switch setting at the input port, simply depress the RETURN key 
on the Apple keyboard. Of course, the switch settings are already in 
binary format, so the correlation between the displayed binary value 
and the individual bits at the input port should be easy. 

Do not remove the circuit from your breadboard, and do not turn 
off the power. Both the program and the circuit will be used in the 
next experiment. 

EXPERIMENT NO. 5 
MULTIBYTE INPUT PORTS 

Purpose 

The purpose of this experiment is to show you how multiple bytes 
of information may be input and processed by a BASIC program. 

Discussion 

Not all input devices transfer only one byte of information to the 
Apple computer. Some devices may require 9 or more bits. In this 
experiment, you will simulate two input ports through the use of the 
input port that was constructed in Experiment No, 4, Refer to Exper- 
iment No. 4 for construction details of the input port. We recom- 
mend that you work through Experiment No. 4 before proceeding 
with this experiment, if you have not already performed it. 

Step 1 

If you do not have an input port connected to your Apple com- 
puter, we refer you to Experiment No. 4, The circuit developed in 
that experiment must be used. 

Step 2 

In handling multibyte data, the Apple must be programmed so 
that the various bytes are ordered from most-significant to least-sig- 
nificant byte. In this experiment, we shall use byte "M" as the most- 
significant byte ( MSBY } and "L" as the least-significant byte 
(LSBY). Since the Apple will interpret 8-bit values as decimal num- 
bers between and 255, can you suggest an equation or series of 
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operations that can be used to obtain the decimal equivalent for a 
two-byte binary number? 



Since the MSBY is "offset" by a factor of 256, you can use the follow- 
ing relationship: 

VALUE = (M * 256) + L 

where VALUE is the final decimal value of the 16-bit word. 
Step 3 

To test this equation, enter the following program into the com- 
puter; 

200 INPUT "SET MSBY ON SWITCHES ";A$ 

210 m = PEEK(49319) 

220 INPUT "SET LSBY ON SWITCHES ";A$ 
230 L = PEEK (49319) 
240 V = (256 + M) + L 
250 PRINT V 
260 GOTO 200 

Now run the program, starting it by entering GOTO 200, and press- 
ing the RETURN key. When the computer asks, "SET MSBY ON 
SWITCHES?" set die eight bits for the value of the MSBY on the 
eight switches. Depress the RETURN key on the keyboard. When 
the computer asks, "SET LSBY ON SWITCHES?" change the eight 
switches so that they represent the eight bits that you wish to enter 
for the LSBY value. When the switches have been set, depres.s the 
RETURN key so that the computer will know that you are ready. 
Now the decimal value should be displayed on the video monitor. 
Some typical 16-bit values that you might wish to try are listed be- 
low. Fill in the decimal value for each, as generated by the Apple. 
You should be able to check these fairly quickly with the aid of a 
calculator. 

MSBY LSBY VALUE 

llOOlOlO 11000001 

iiooom oooinoi 

00000001 10000001 

You should find values of 51905, 50973, and 385. 
Step 4 

The following program is a combination of the binary output pro- 
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gram, and the two-byte decimal calculation program. It will allow 
you to input two 8-bit bytes to represent a 16-bit value, display the 
decimal value and the binary value. 



10 A = 32768 

20 FOR S = 1 TO 2 

30 FOR Q = 1 TO 8 

40 IF B-A<0 THEN GOTO 100 

50 PRINT "1"; 

60 B = B-A 

65 A = A/2 

70 NEXT Q 

75 PRINT " ",-:NEXT S 

80 PRINT: GOTO 200 

100 PRINT "0"; 

110 GOTO 65 

200 INPUT "SET MSBY ON SWITCHES "; A$ 

210 M = PEEK(49319) 

220 INPUT "SET LSBY ON SWITCHES "; A$ 

230 L = PEEK(49319) 

240 V = (256 * M) + L 

250 HOME: PRINT V 

260 B = V: GOTO 10 



Step 5 

Run the program by entering a GOTO 200 command and then de- 
pressing the RETURN key. Set values for the MSBY and LSBY on 
the switches. There should be a correlation between your switch set- 
tings and the binary bits that are displayed on the screen. You should 
be able to convert the binary value into a decimal value fairly easily. 
The 16-bit binary value has been "split" into two 8-bit values so that 
you can easily compare the bits with your switch settings. 

Now that you have seen how the Apple can operate on two 8-bit 
bytes to reconstruct a 16-bit value, you should realize that other 
types of operations could have been performed, too. Although only a 
single input port has been used in this experiment, it would be easy 
to construct another one with a new device address to provide the 
additional byte of data required in the 16-bit appUcation that has 
been simulated in this experiment. 

You probably noticed that a new variable, A$, was used in this ex- 
periment, and in the last one. This is a "dummy" variable that has 
been used so that the program can be halted at a predetermined 
point so that the experimental conditions could be changed before 
the computer is allowed to go on. The A$ variable is a string vari- 
able, and when the RETURN key is pressed a null, or "nothing," 
string of characters is assigned to this variable. This is just a "trick" 
that halts the computer until we depress the RETURN key. 
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The interface circuit used in this experiment will be i^ed in tihe? 
following experiment, so it should be saved. The software wfll not 
be used, so the computer and interface may be turned off. 

EXPERIMENT NO. 6 
INPUT PORT APPlfCATtONS 

Purpose 

The purpose of this experiment is to show you how an input port 
imy be used for contccd ff^&aticHaSi 

la this experiment, the 8-bit input port will b© med to transfer in- 
formation to the Apple, but the Apple will process the eight bits of 
data in a nonnumeric fashion. In this way, the state of eight external 
devices will be monitored. 

1 

If yoii do not have an input port connected to your Apple computer, 
we refer you to Experiment No. 4, The input port described in that 
ecperinieiit wiU be tise^ fiiJbjesfjolIfming steps. 

lib mmy esese^, ^ ^mtptOsi will be used tti prelQess nonnumeriiE: 
information that tells the computer about the stljtus or state of ex- 
ternal devices. In such a way, it is easy to deteip^ when devices 
are on or off, valves op^ ei &ciie^ B\&^<m w^ Mi^mm, md so on. 

Enter the following program into your computer and run it. This 
program demonstrates how a value may be used to cause the com- 
p^uter to tal^ a pr#pre^ramMi ect^se a/d&m: 

10 INPUT A$: HOME 

20 A = PEEK(49319) 

30 IF A>127 THEN GOTO 70 

40 PRINT "INPUT <= la?" 

50 GOTO 10 

70 PRINT "INPUT > 127" 

80 GOTO 10 

Step 3 

You must press the RETURN key to cause the computer to execid^e 
tbe infat mmj^^mti st^s. Set the lo^c mr^^m ^ iapt^t 
port to a value that is less than 127 (00000000 to 01111110) and press 
RETURN. What happens? Try this with a value of 127 or greater 
COUIUU ta Ullllll). What happens? What happens when the 
bioaiy valui^ is ^qual tp 127 (01111111)? You should see the correct 
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message for each value that is input to the computer. This program 
illustrates how the computer can be used to make a decision based 
upon a value. In some cases, the value of an individual bit may be 
used as the basis for a decision. The binary conversion program pro- 
vided in Experiment No. 4 allowed you to see a binary equivalent for 
a decimal value. This program made decisions based upon the value 
of individual bits, so that it could determine whether to display a 
one in each bit position. 

Step 4 

In this step, the basic binary-display routine will be used, but 
rather than display ones and zeros, the computer will display "ON," 
for a logic one and "OFF," for a logic zero. You should be able to 
modify the program frpm Experiment No. 4 to do this, just by chang- 
ing the PRINT statements, but the following program is provided for 
you. Note that the program from Experiment No. 4 has been 
"moved," or relocated to higher Hne numbers. Before you enter this 
program, remember to delete the old one, if you have not already 
done so by turning off the power. The NEW command may be used 
to delete the old program. Simply type NEW and then press the 
RETURN key. 

410 INPUT A$: HOME: A = 128 

420 B = PEEK (49319) 

430 FOR Q = 1 TO 8 

440 IF B-A <0 THEN GOTO 500 

450 PRINT "ON "; 

460 B = B-A 

470 A = A/2 

480 NEXT Q 

490 GOTO 410 

500 PRINT "OFF "; 

510 GOTO 470 

Note: There are two spaces after ON, and one space after OFF. This 
generates equal spacing. 

Run the program. Remember that the switches should be set, and 
then the RETURN key pressed, to perform the "conversion" and dis- 
play. You should see that a line of ON and OFF messages is dis- 
played, with the ON notation for the logic one bits, and the OFF no- 
tation for the logic zero bits. The PRINT statements in the program 
could be changed to display OPEN and CLOSED, UP and DOWN, 
and other similar notations for the bits. 

Step 5 

While the simple program in Step 4 has some uses, the display of 
the ON and OFF messages in column format may be more useful. 



The HTAB and VTAB commands in BASIC may be used to generate 
such a vertical display of the conditions. The same basic program is 
used, with the necessary changes marked ( * ) . You need to leave the 
spaces after ON and OFF in lines 450 and 500, respectively. 



•400 H = 20: V = 8 

410 INPUT A$: HOME : A -= tM 

420 B = PEEK(49319) 

430 FOR Q = 1 TO 8 

440 IF B-A<0 THEN GOTO 500 

*450 HTAB Hi VTAB % WW "SSN ^ 

460 B = B-A 

*470 A = A/2: V ^ V + l 

480 NEXT Q 

*490 GOTO 400 

*500 HTAft Hi VTAB V: PS (NT "OFF 

510 GOTO 470 



You should now observe that the display of ON and OFF conditions 
is vertical, ^nee tiie HTAB and VTAB ajinn:^^ have beea WJSed M 
"move" the cursor in a vertical fashion. 

Thus, the ON and OFF conditions can be displayed in a number 
etf In fact, in sowm ®Grapwt®I3tj graphical representations and 

alphanumeric cbaracteES Hfflff be ial«d so that the ON/OFF condi' 
tions may be displayed near a ptetorlal isqpfflessiitatton of 13if device 
or process being monitored. 

While the program is running, make changes to the switch settings 
to dOnfirm that the program 8S1ii |te input port sm woddng prop- 

You may want to run the program continuously, so that the 
switches may be changed, and the ON /OFF conditions monitored, 
without the need to press the RETURN key each ttlii«# ]»w display 
is needed. The INPUT AS is the "dummy" input command that 
causes the computer to stop and wait for you to press the RETURN 
key. Remove this StatTOSEtt ^Ptti the pfj^sSTO, ^iB that lia# 41J(? toate 
like this : 

410 fiCmSi A = ilB 

Nwwifi tbe jjRBpafli* D«i#f ^fluf pravide « r!^t$©n^ 



Our display flickered feadly^ since the HOME cfminiand clears fJie 
entire screen and positions the cursor in the upper left-hand corntaf 



of die monitor screen each time the computer restarts the program. 
This takes time, and it slows down the display. Can you suggest any 
further changes to the program to reduce or eliminate the flicker? 



Step 7 

By removing the HOME command, you can reduce the time that 
the Apple takes to clear the entire screen and "home" the cursor to 
the upper left-hand corner of the video display area. When the 
HTAB and VTAB commands are used, they position the cursor at 
exactly the right place to print each ON or OFF on each line, one 
per bit. If no spaces are left after the "ON" at line 450, the printing 
of the ON would not cover the last F in OFF, and you would see 
ONF, instead of ON. Thus, the spaces are needed to "erase" any 
diaracters remaining on a line. 

We suggest that you use the following for line 410 in your pro- 
gram: 

410 A = 128 

Now, start the program by typing in HOME: GOTO 400, and then 
pressing ENTER. If you do not use the HOME command, the pro- 
gram will simply write over whatever is on the screen. The HOME 
command clears the screen for you just before the program is started. 

Step 8 

The VTAB and HTAB commands can also be used to generate 
titles or captions for each of the eight lines of information in the dis- 
play. Several captions follow, and you may add or change the ones 
provided: 

5 HOME 

10 VTAB B: HTAB 1 

15 PRINT "ACID PUMP"; 

20 VTAB 9: HTAB 1 

25 PRINT "BASE PUWP"; 

30 VTAB 10: HTAB 1 

35 PRINT "HEATER"; 

40 VTAB 11: HTAB 1 

45 PRINT "MIXER"; 

50 VTAB 12: HTAB 1 

55 PRINT "FLUSH CYCLE"; 

60 VTAB 13: HTAB 1 

65 PRINT "DISHWASHER"; 

70 VTAB 14: HTAB 1 



75 PRINT "VACUUM": 
80 VTAB IS: HTAB \ 
85 PRINT "DRYER"; 

We suggest that you add these lines to your program if you plan to 
go ahead with Experiment No. 7. You should test your program after 
you add these lines. 

The hardware and the software used in this experiment will be 
used in the next experiment, so you should not dismantle your cir- 
cuit, nor should you remove power to the computer. 

EXPERIMENT NO. 7 
INPUT PORT APPLICATIONS (II) 

Purpose 

The purpose of this experiment is to show you how logical opera- 
tions may be performed on data. 

Discussion 

This experiment will use and operations, and they will be per- 
formed on the ON /OFF information from eight external "sensors." 
The conditions of these sensors will be used to trigger actions in the 
computer. 

Step 1 

The program used in this experiment is the same as the one used 
in Experiment No. 6, If it has not been completely entered into your 
computer, you must enter it and test it. If it has been entered and 
tested in the previous experiment, you may wish to check it against 
the following listing: 



5 


HOME 




TO 


VTAB 


8: HTAB 1 


15 


PRINT 


"ACID PUMP"; 


20 


VTAB 


9; HTAB 1 


25 


PRINT 


"BASE PUMP"; 


30 


VTAB 


!0: HTAB 1 


35 


PRINT "HEATER"; 


40 


VTAB 


11: HTAB 1 


45 


PRINT 


"MIXER"; 


50 


VTAB 


12: HTAB 1 


55 


PRINT 


"FLUSH CYCLE"; 


60 


VTAB 


13: HTAB 1 


65 


PRINT 


"DISHWASHER"; 


70 


VTAB 


14: HTAB 1 


75 


PRINT 


"VACUUM"; 


80 


VTAB 


15: HTAB 1 


85 


PRINT "DRYER"; 


4O0 


H = 


20; V = 8 
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410 A = 128 

420 B = P£EK(49319) 

430 FOR Q = J TO 8 

440 IF B-A<0 THEN GOTO 500 

450 HTAB H: VTAB V: PRINT "ON "; 

450 B = B-A 

470 A = A/ 2: V = V+1 

480 NEXT Q 

490 GOTO 400 

500 HTAB H: VTAB V: PRINT "OFF "; 
510 GOTO 470 

When successfully loaded and tested, the program should generate 
a display such as that shown in Table 6-1. The various ON and OFF 
conditions shown by your computer will probably be different, based 
upon the logic switch settings at your input port. 

Step 2 

Make notes alongside of Table 6-1 to indicate which bits at the 
input port correspond to the different labels. You can do this by 



Table 4-1. Control Program Output 



ACID PUMP 


ON 


BASE PUMP 


OFF 


HEATER 


ON 


AAIXER 


ON 


FLUSH CYCLE 


ON 


DISHWASHER 


ON 


VACUUM 


OFF 


DRYER 


OFF 



testing the input bits, or by analyzing your program. You should 
find that bit D7 is the "ACID PUMP," bit D6 is the "BASE PUMP," 
and so on, down to bit DO, which is the "DRYER " 

Step 3 

Refer to Chapter 4, Example 4-3 and use the Apple monitor to 
enter this assembly-language program into the computer. You can 
simply type CALL -151 and then RETURN to enter the monitor. 
Check that your program has been entered correctly. Remember that 
the monitor program uses hexadecimal numbers. If you do not know 
how to use the monitor, refer to Apple II Reference Manual, or fol- 
low these steps : 

1. Press the RESET key and type CALL -151, and press the 
RETURN key. The Apple should respond with an asterisk ('). 

2. Type 0300:00 00 00 48 AD 00 03 2D 01 03 8D 02 03 68 60 Leave 
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a space between the two-digit groups. Use 00 for the first three 
values in the program. 
3. Press the BETURN key, tji>e 02FF, press the KETURN key, 
ttesE IBSTCfRN key twice^ and check the data against 

is^itat is to ffie Isfag ta B^jmgle 4-St,; and what k aMted afeom. 

Step 4 

To test the assembly-language program, enter the program shown 
below into the computer and run it. Make the necessary decimal-tp- 
binajry and binary-tenkfciiaal coovei^cms tm scrap paper ti AiA 
your resBilts. Press RESET to return to BASIC. 

1000 POK6 t076jPC»^ n,03iPOKE 12^ 
1010 INPUT "MASK BYTE "; Mi POKE 768,M 
1020 INW 'ttATA fttTE "; D: POKE 769,D 
iraO Q = USRCW; PRINT "ANSWER PeEK(770) 
1040 GOTO TOIQ 

If your answers prove to check with those that yo^ calculate by 
tiand, go on to the next step. If not, carefully check that tftfe aSiseitt- 
bly- language steps have been entered correctly, and test the program 
again. Remember, the errors coiild be in your "hand" calculations. 

Step 5 

We now want you to modify yoiur program so that it will detect 
Wfen iirt^ Bf applteC^, DrSHWMHfiR, DRYER, or VACUUM 
are on, and whenever the ACID PUMP and BASE PUMP are both 
on. The logical and assembly-language subroutine can be used, al- 
though there are probably other solutions that will also work. 

Can you suggest a method of making these determinations? We 
suggest that you review the logical and operation, as presented in 

Chapter 4. Tthfa^ skmA vi^iMiiim. b$ ^y me pKi^i^negd to 
Table 6-2. 



The logical and operation can be used to mask out the unwanted 
bits, D3-D0 for the pump test, and bits D7-D3 for the appliance test. 
Thus, two "masks" must be established, one for the pumps, and one 
for IhBi ^^JmKm* Wk^m&M^-^b^ Hxasks be, in d^^sd and to 
binaryi 

lit 



Table 6*2. Conrrol Condttlens To Be Defected 



D7 


D6 


D5 


D4 


D3 


D2 


D1 


DO 




1 


1 


X 


X 


X 


X 


X 


X 


ACID AND BASE PUMPS 


















BOTH ON 


X 


X 


X 


X 


X 








1 




X 


X 


X 


X 


X 





1 







X 


X 


X 


X 


X 





1 


1 




X 


X 


X 


X 


X 


1 








ANY APPLIANCE ON 


X 


X 


X 


X 


X 


1 





1 




X 


X 


X 


X 


X 


1: 


1 







X 


X 


X 


X 


X 


1 


1 


1 





X = Don't care, logic one or zero. 



The mask for the pumps would be llOOOOOOa, or 192, while the mask 
for the appliances would be 000001 II2, or 7. When these masks are 
ANDed with the input values from the sensors, or logic switches, the 
desired bits will be "filtered" through the mask. 

Step 7 

Now that the two masks have been established, suggest some soft- 
ware steps that could be used to determine the state of the "filtered" 
bits. You need to think of the individual bits, as well as the decimal 
equivalents for the bits. You may use new variables, if you need to. 



We used a new variable, C, to represent the value input from the 
sensors. This allows the variable B to be used independently in the 
ON/ OFF display portion of the program. If you use the variable B, 
you will find that it is always zero. We will let you try and find 
out why. We used either: 

POKE 76S,7:POKE 769:C.Q=USR(0) 
IF PEEK(770) = THEN . . . 
or 

POKE 768,7: POKE 769,C:Q=USR(0) 
IF PEEK(770) >0 THEN . . . 
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to detect the appliances, and similar steps to detect the pumps. In 
each case, the THEN . . . statement is executed on one condition, 
and the program continues on in the other. 

Step 8 

In order to test your program ideas, add steps to the basic flag- 
detecting program so that DANGER is printed on the display if 
both pumps are on, and APPLIANCES is printed if any of the ap- 
pliances are on. Write your program steps in the following space 
and review them carefully before you change the program. Remem- 
ber that you will need a line just like line 1000 in the program given 
in Step 4, if you are going to use the assembly-language subroutine. 
This program line initializes the three locations used by the USR 
command so that it points the computer to the start of the correct 
subroutine. 



Your program steps will probably look like these: 

420 B = PEEK(49319): C = B 



490 GOTO 600 



600 POKE 76fi,7: POKE 769,C 

605 Q = USR(O) 

610 IF PEEK(770) = THEN 700 

615 HTAB 20:VTAB 17: PRINT "APPLIANCES"; 

620 POKE 768,192 

625 Q = USR(0) 

630 IF PEEK(770) <> 192 THEN BOO 

635 HTAB 2C>:VTAB 18: PRINT "DANGER"; 

640 GOTO 400 

700 HTAB 20:VTAB 17: PRINT " 

710 GOTO 620 

800 HTAB 20:VTAB 18: PRINT " "; 

810 GOTO 400 
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Test your program. You may have forgotten steps to clear the AP- 
PLIANCES and DANGER displays from your screen. You may also 
have forgotten to use three POKE commands to load the informa- 
tion required by the USR command. You can do this without add- 
ing another step to your program, simply t>pe in the POKE com- 
mands, follovi^ed by a RETURN. They only need to be executed 
once. 

The commands for printing spaces at lines 700 and 800 are used 
to clear the APPLIANCES and DANGER signals that are displayed. 
This program could be much more complex, containing steps to use 
reverse video, or to flash the display when an emergency condition 
is sensed by the program. You should realize by now that the soft- 
ware can handle both mathematical and logical operations. You 
should also see that the use of assembly-language subroutines is not 
too difficult. 

You may turn off the computer, although the assembly-language 
AND operation program will be used again. The input port will also 
be used again, so do not dismantle your circuit. 



EXPERIMENT NO. 8 
CONSTRUCTING AN OUTPUT PORT 

Purpose 

The purpose of this experiment is to have you construct a simple 
8-bit output port and investigate its use. 

Discussion 

In this experiment, a simple 8-bit latch circuit will be used to 
construct an output port. The output port will be used in this ex- 
periment, and in some of the following experiments, in which it 
will be necessary to transfer information to external devices. Two 
SN7475 quad latch integrated circuits will be used. 

Pin Configuration of the Integrated Circuit (Fig. 6-9] 

ENABLE 

10 zg 15 12 GMD IB 3Q *Q 

FUNCTION TABLE 
(£ach Latch 1 




INPUTS 


OUTPUTS 


□ 





L H 
H H 
X L 


L H 

H U 
Qo So 



njjiijiiriLiiiri_!Jii^^ 

iQ ID 2D ENABLE Vcc 3D 40 40 

fi^, 6-9. SN7475 4-bit match chip pin conflguration 



H = high lavsl, L > tOw l«v«l, X ■ \twm\»v»nX 
Q{) = tha lavdl of □ btlort thi high-to iow cransition ol G 
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Step 1 

The gating circuit used in Experiment No. 2 will be used in this 
experiment. If this circuit Ls not available on your solderless bread- 
board, we suggest that you perform Experiment No. 2 and then this 
experiment. The gating circuit may also be wired and used directly. 
Refer to Fig. 6-4 for the circuit details. 

Step 2 

Wire the circuit shown in Fig. 6-10. Two SN7475 latch integrated 
circuits are required, along with eight individual lamp monitors, or 



D7- 



DATA 
BUS 



00 — I 



DEV. SELr 



+ S GND 

ii 



SN7475 



+ 5 GND 

Ii 



SN7475 



LAMP 
MONITORS 



LAMP 



MONITORS 



Fig. 6-10. Simple B4>it output port tchematie. 



equivalent logic level detecting circuits. Do not connect the device 
select input, DEV SEL, at this time. 

Step 3 

Refer to the circuit shown in Fig. 6-4. Try to determine which of 
the three control outputs. A, B, or C, would be used to control the 
latch enable inputs that are connected to the DEV SEL line. Which 
one would you use? Why? 
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The A output, RD 49319, has already been used and RD 49318 
would not work, since it is decoded for an input port. The WR 49318 
output (C) would be the choice to use. It provides a positive pulse 
which is the same type of pulse required by the SN7475 latch chips. 
This output is also decoded for an output device. You should re- 
member that the 7 and 6 output pins from the decoder on the printed 
circuit board actually correspond to decoded addresses 49319 and 
49318, respectively. 

Make a connection between pin 13 on the SN7402 and pins 4 and 
13 on both of the SN7475 latch chips. This is the DEV SEL connec- 
tion shown in Fig. 6-10. 

Step 4 

To test the output port, enter the following program into your 
computer: 

10 A = 

20 POKE 49318,A 

30 END 

Preset the variable A to zero, as shown, and run the program. What 
happens to the lamp monitors? 



They should be unlit, since zero has been transferred to the output 
port. Now set A to 255 and run the program again. You should see 
all of the LEDs light. If these conditions have not been found, re- 
check your circuit and the test program. 

Step 5 

The program may be changed so that you can easily enter new 
values from the keyboard. The new program is: 

10 INPUT A 

20 POKE 4931 8,A 

30 GOTO 10 

You may try any values that you choose, but we suggest that you 
try powers of two first, 0, 1, 2, 4, 8, etc., since these will test the indi- 
vidual LEDs. 
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Since an 8-bit output port can only display values between zero 
and 255, what happens when you try to output a value that is out- 
side of this range? Would you expect to see a "portion" of the value, 
say the eight least-significant bits? Try running the program with 
the value 256. What happens? 



The Apple displays 

?ILLEGAL QUANTITY ERROR IN 20 

which indicates that the value was not within the proper range for 
the function that was requested. The line number for the "error" 
is provided in the error message. Negative numbers are also "caught" 
in this way. 

Step 6 

Restart the program and enter a value of 90. You should observe 
a display of 01011010 on the lamp monitors. Now try and enter a 
value of —24. When the error is detected, and the error message 
displayed, does the displayed value change? 



No. Error conditions are detected prior to any attempted use of the 
POKE function. How do you think the Apple v^^ll handle fractional 
numbers? Enter a decimal fraction, such as 6.01. What is displayed? 



The Apple will "strip ofiE" the decimal portion of the number. You 
may wish to experiment wdth some other numbers, too. 

Step 7 

Can you write a short program that could be used to increment 
a value from to 255, displaying each new value on the LEDs? 
Write your program in the space below, and test it. What do you 
observe? Can you make the program loop back on itself so that the 
incrementing counting is displayed again and again? 
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We used the following program: 

10 FOR A = TO 255 
20 POKE 49318,A 
30 NEXT A 
40 GOTO 10 

Remember that you cannot go above 255, or below 0, without gen- 
erating an error message. You may wish to put a short time delay 
in your program so that the LEDs do not flash on and off so quickly. 
An example of such a time-delay step is : 

25 FOR T = TO 500: NEXT T 

You should see that it is fairly simple to construct an output port, 
and to control it with simple software commands. 

The output port will be used in the following experiment, but the 
power may be shut off, 

EXPERIMENT NO. 9 
OUTPUT-PORT AND INPUT-PORT INTERACTIONS 

Purpose 

The purpose of this experiment is to show you how input-port 
and output-port commands can be used in the same program. 

Discussion 

In many cases, input ports and output ports will be used together 
in interface circuits. They will be controlled by PEEK and POKE 
commands within the same program, and there frequently will be 
transfers of information between the ports. In this experiment, you 
will observe how such ports may be used together in a simple circuit. 

Step 1 

The simple input port (Experiment No. 7) and output port (Ex- 
periment No. 8) used previously will be used in this experiment. 
We refer you to Experiment Nos, 2, 3, and 8 for the appropriate 
circuit details. 

Step 2 

Once the input port and output port have been constructed, enter 
the following program into your computer and run it. It is used to 
test the 1/ O port circuits. 

10 A = PEEK{49319) 
20 POKE 493i8,A 
30 GOTO 10 
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As you actuate the logic switches at the input port, you should see 
the corresponding bits at the output port change, consistent with 
the switch actions. If this is not the case, recheck your circuits and 
your program. 

Step 3 

In this step, two values will be entered from the keyboard and 
then displayed on the LEDs. At this point, you should be able to 
write a short program to do this. Make an attempt in the space 
provided: 



We used the following program, in which a most-significant byte 
(MSBY) and a least-significant byte (LSBY) were simulated: 

10 INPUT "MSBY ";A$: M = PEEK{49319) 
20 rNPUT "LSBY ";A$: L = PEEK(49319) 
30 POKE 49318^ 
40 INPUT A$ 
50 POKE 4931 8, L 
60 GOTO 10 

In this program, the string variable, A$, has been used as a "dummy" 
variable to "stop" the computer so that you can perform the neces- 
sary actions before the program goes on. 

Step 4 

Run your program. You should be able to enter two values into 
the computer. When you type RUN RETURN, the computer is 
ready for you to set the MSBY on the switches. After you have done 
this, press the RETURN key, so that the computer can perform the 
data acquisition step. Then, set the LSBY on the switches and again 
press RETURN. When the LSBY has been acquired, the MSBY will 
be displayed. By pressing RETURN, you will cause the computer 
to display the LSBY. 

Step 5 

This program shows how the computer can acquire and store val- 
ues for later display. Eight bits of information are easy to manipu- 
late. How could a number between and 65535 be displayed on 
two output ports? 
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These numbers would have to be "split" into an 8-bit MSB5f and axt 
8-bit LSBY, Can you suggest how this might be done? 



The number could be divided by 256 to get the MSBY as the integer 
portion of the answer. For example, if we start with the number 
lOmi 

imsBlf^ '=• Mma 

The integer poiliaa af &m result^ 42, when converted into an 8-bit 
binary number, wOudd be iSl* l^iSBY &f vSkiK, The WB'f eSa 

also be calculated? 

Here, the 171 must jte> bB ©Sn^s^itfed iato ^btt eqtiiVidi^^^ 
to be the LSBY. 

A BASIC program can be written for the Apple to perform these 
luiietiMJ*. Cpijld you tiprtt^ it? 

10 INPUT "VALUE ",- W 

20 M = V/256 

30 L = V - INT(M) * m 

40 PRINT INT(m), L 

50 INPUT A$ 

60 POKE 49318,M 

70 INPUT A$ 

80 POKE 49318,L 

90 ©OTO 10 

The MSBY and the LSBY will be displayed on the video monitor in 
their decimal form. The INT command has been used to "strip" the 
dedmal fraction from the value for M, for clarity. This is not ye- 
qttired for the POKE operation, since the decimal fraction ijrfll ^ 



Step 7 

Enter our program, or yours, into the computer and test it. You 
will have to press the RETURN key to display the MSBY on the 
LEDs, and you must press it a second tiBie to display the LSBY. 

Can you enter mfeaes greafe^ ikm Cm they h$ ieomarerted 

and displayed? 



Yes, you can erileriSiem, and fhey wfll lje eoHvetted, but you cannot 
display them, since they will generate results that are greater than 
256 in the MSBY. This generates an error condition. Can you do 



You can add some steps to your projgram that will check the range 
#fc -vsibm -Wfoie alifeaiigittB^ ^^ mmmm^m. aJsit- h& 

added to remove any fracSwasl poiHoaas t>£ &e Bifflafer* The 
ing steps can be used: 

12 IF V < = 65535 AND V > = THEN tS 

^4 PRINT "VALUE QUT OF mum Tft¥ AGAIN"! ©OT0 19 

18 V = !NT(y) 

You Blight want to t^ wfliieEg &B*itt6^ |»-yffl|ir program* We^miA 
steps such as these prevent errors, and they orient the prograna 
toward the user. Keep this type of programming in mind when you 
wdtn eomplex pf^eams of ymx mm 



EXPERIMENT NO. 10 
DATA LOGGING AND DISPLAY 

purpose 

The purpose of this experiment is to show you how the input pd£t 
may be used to acquire information, and how the computef ieaa 
sismss ^i^M^t^mm^^m I$lir display at the LEDs. 

Dbeussion 

In m^^tm^v « sa# «i i& *4tlc«ss ^ ^ acquired fronn 
the three-state input port, and will be displayed on the LEDs at a 
later time. More flexible display ideas will also be developed and 

m 



Step 1 

The input port and output port described previously will be used 
in this experiment. By now, you should be familiar with these types 
of ports, but we refer you to Experiment Nos. 2, 3, and 8 for the 
necessary details. If you have not performed these experiments, we 
recommend that you do so before going on with this experiment. 

Step 2 

In this experiment, you will use the computer to acquire and dis- 
play a set of values that are acquired from the input port. While 
these may be acquired with software steps such as: 

50 INPUT AS 

60 Q = PEEK(49319) 

70 INPUT A$ 

80 R = PEEK(49319) 

this takes a great number of software steps to acquire a small amount 
of information. Can you suggest an alternative? 



A list of values can be acquired by using a loop, and an array can 
be used to store the information, so that a new variable need not 
be assigned to each new data value. Can you vmte a short program 
that could be used to acquire 10 data points? 



We used the following program, which should look somewhat like 
yours. Note the use of an array to store the information. 



10 DIM A(10) 

20 PRINT "START" 

30 FOR P = 1 TO 10 

40 INPUT A$ 

50 A<P) = PEEK(49319) 

60 NEXT P 

70 PRINT "START DISPLAY. . ." 



80 FOR P = 1 TO 10 

90 GET At 

100 PRINT A(P): POKE 49318,A(P) 

110 NEXT P 

T20 PRINT "END Of RUN": END 

In this program, you must press the RETURN key to cause the 
computer to acquire a value. When the computer prints "START 
DISPLAY . . ." on the screen, it will display a value that it has stored, 
each time you press RETURN. The value will also be displayed on 
the LEDs in binary form. Note that a GET A$ command has been 
used here, instead of an INPUT A$. Is there any difiFerence? 



Yes, the GET A$ command suppresses the question mark (?), and 
any character key (A, &, I, etc.) may be used in place of the RE- 
TURN key. The alphanumeric symbol is not displayed. This "cleans 
up" the display of the data values. 

Steps 

Run either your program, or ours, to acquire 10 data values. Once 
the values have been acquired, use the computer to display them. 
What results do you observe? 



You should find that your values have been stored properly, and 
that they are also displayed and printed on the video monitor. If you 
do not require the values at the output port, could you modify the 
program so that it only displays the values on the monitor? 



Yes. Simply change line 100 to: 

100 PRINT A(P) 

and remove line 90. 
Step 4 

The low-resolution graphics mode on the Apple could also be 
used to display the value.s in graphical form. We suggest that you 
attempt to use the HLIN command to draw a horizontal set of lines 
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that represent the relative values that have been input from the port. 
Remember that there are hmits on the dimensions of the screen area 
for the HLIN command. These hmits are 39 points in each direction. 
Note your display program steps in the following space: 



We used the following steps to generate a horizontal bar graph of 
the information: 

80 GR: COLOR = 5 

90 FOR P = 1 TO 10 
100 D = A(P)/6.5 
110 HLIN 0,D AT P 
120 NEXT P 
130 END 

These steps were added to the program that we developed in Step 2. 
Try your program, or the one shown here. 

In this set of program steps, the data value has been divided by 
6.5, so that instead of having a range between and 255, the range 
is "condensed" to be to 39. The subscript for the array has also 
been used to increase the starting position of each horizontal line. 
The data starts at the top of the screen f or A ( 1 ) , and proceeds down 
the screen for the later data values. You could also use the value 
of P to change the color for each of the horizontal Unes. 

Step 5 

Additional changes can be made to the program so that a time- 
delay routine is used in place of the INPUT A$ command. This 
would mean that data values would be obtained at definite intervals, 
as programmed in the delay routine. You would no longer need to 
press the RETURN key to have a new data value acquired. 

Change your program so that a time delay routine is used in place 
of the INPUT A$ command at line 40. Make the delay fairly long, 
about 2 or 3 seconds. Here is an example of a useful routine: 

40 FOR T = fo 2000: NEXT T 

Connect the logic probe to the "A" output, pin 1, on the SN7402 
NOR gate. The acquisition of a data value from the three-state in- 
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put port will cause the logic probe to flash the yellow LED. This 
will tell you that a value has been acquired. 

You may want to change your program to acquire more than 10 
points. With the simple display routine, you can acquire up to 
39 values. 

Make the necessary changes to your program so that a time delay 
is used to synchronize the acquisition of the data from the input 
port. Run your program. You may want to increase the delay so 
that you can easily change the switches. 

Your program should now look something like this: 

10 DIM AdO) 

20 PRINT "START" 

30 FOR P = 1 TO 10 

40 FOR T = TO 2000: NEXT T 

50 A(P) = PEEK(49319) 

60 NEXT P 

70 PRINT "START DISPLAY. . 

80 GR: COIOR = 5 

90 FOR P = 1 TO 10 
100 D = A(P)/6.5 
110 HLIN 0,D AT P 
120 NEXT P 
130 END 

Have you noticed that not all of your values cause changes in the 
display? Try entering values of 0, 1, 2, 3, and so on up to 9, You may 
need to slow down the delay, or to go back to the INPUT A$ com- 
mand at line 40 so that you have sufficient time to make the changes 
to the switches. What do you find in the display when you enter 
these numbers? Why? 



The values 0-6 show the same value on the display, and the values 7-9 
also show the same value, but one "square" greater than the previous 
values, 0-6. The reason for this is that all the values are "compressed" 
to be between and 39, so the resolution is cut from one-part-in-256 
to one-part-in-40. Thus while the data has 256 discrete values, the 
display only can accommodate 40 different values. The division of 
the value by 6.5 "compresses" it to fit in the space available on the 
display. You will aLso note that a value of zero still "lights" one 
square on the video monitor. Unfortunately, the BASIC program 
will generate one "lit" square for the command HLIN 0,0 at X, 
wherever X is on the screen. 

The point of this experiment is that the computer can be used 
to acquire information and display it, or use it, in many ways. The 
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input and output ports are simply additional ways of getting infor- 
mation into and out of the computer. 



EXPERIMENT NO. 11 
SIMPLE DIGITAL-TO-ANALOG CONVERTER 

Purpose 

The purpose of this experiment is to show you how a simple 8-bit 
digital-to-analog converter (DAC or D/A) can be interfaced to 
the Apple. 

Discussion 

A simple D/A converter, the Signetics NE5018 8-bit converter, 
will be interfaced to the Apple. Although we have not discussed 
analog converters, they have been thoroughly described in Micro- 
computer-Analog Converter Software and Hardware Interfacing 
(Howard W. Sams & Co., Inc., Indianapolis, IN 46268). We refer 
you to this book for additional information about these devices. 
Other topics, such as sample and hold amplifiers, analog multiplex- 
ers and instrumentation amplifiers are also described. 

Pin Configuration of the Integrated Circuit (Fig. 6-1 1) 



Fig. Signstici NES018 S-bit 

D/A converter chip 
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Step 1 

Two additional power supplies are required in this experiment, 
-1-12 and —12 volts. They will be used to power the D/A converter 
integrated circuit. Be sure that these power supplies are available, 
and that they are adjusted for the proper voltages before proceeding. 

Wire the circuit shown in Fig. 6-12. The device-select pulse is ob- 
tained from the SN7402 nor gate circuit that has been used in 
previous experiments. The device-select signal is available from 
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DATA 
BUS 




VDAC 



DEVICE SELECT 



Fig, 6-1 2. Schemalic for tlmpU D/A converter interface, uting NE501S D/A 
converter chip. 

point C (Fig. 6-4), but it must be inverted before it can be used 
by the NE5018 chip, An SN7404 inverter chip may be used for this, 
as shown in Fig. 6-13. Wire this inverter circuit, too, connecting 
the input of the SN7404 inverter to pin 13 on the SN7402. and w iring 
the output of the SN7404 inverter to the DEVICE SELECT input 
on the NE5018 converter. 

+5 



-TL 



DEVICE SELECT 




SN7404 
2 



DEVICE SELECT 



■.~u- 



Fig. 6-1 3. Simple device-Mlect pulsenn verter ciKuit. 

At this point, carefully check the +12 and — 12-voIt power supply 
connections to be sure that they are correct. If you are using sepa- 
rate power supplies, you must be sure that there is a low-resistance 
ground connection in common to all of them and to the breadboard. 

Step 2 

The NE5018 D/A converter will convert values between and 
255 to voltages between and +10 volts. Since the 0- to 10-volt 
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range has been divided into 256 values, or 255 steps, the voltage in- 
crement available is: 

10 volts/ 255 steps = 39 millivolts /step 

You can probably write a short program that would increment an 
S-bit count and output it to the DA converter. Don't worry about the 
internal operation of the D/A converter, just treat it like an output 
port. Your program will generate a slowly increasing positive volt- 
age ramp. Develop your program in the space below: 



We used the program: 

10 FOR V = TO 255 
20 POKE 4391 8,V 
30 NEXT V 
40 GOTO 10 

A simple voltmeter or volt-ohm-miUiammeter ( vom ) may be used 
to monitor the voltages. Connect the meter between ground and the 
NE5018 VDAC output ( VDAC is positive ). Try your program. Does 
the voltage increase slowly? What happens when the voltage reaches 
about -HlO volts? 



The voltage increases slowly to -1-10 volts. When it reaches this 
value, it quickly changes to zero volts, or ground, and it starts to 
increase slowly once again. 

You can slow the voltage ramp by introducing a short time delay 
routine in your program. We used the following: 

25 FOR T = TO 100: NEXT T 

Step 3 

Develop a program that will generate a negative-going ramp, and 
one that wdll generate a triangular ramp ( slow-up then slow-down ) . 

We used the following programs: 

Nagative ramp 

10 FOR V = 255 TO STEP -1 

129 



20 POKE 49318, V 
30 NEXT V 
40 GOTO 10 
Triangular eutpuf 

10 FOR V = TO 255 
20 POKE 49318, V 
30 NEXT V 

40 FOR V = 254 TO 1 STEP -1 
50 POKE 49318, V 
60 NEXT V 
70 GOTO 10 

You may wish to try either of these programs, or the ones that 
you wrote. Why is the range in one of the triangular output loops 
254 to 1 instead of 255 to 0? 



If the range is 255 to 0, these two values will be output twice, al- 
though you probably couldn't tell the difiEerence on the meter. A 
time delay, or delays, may be useful in these programs. 

Step 4 

Since you know that the voltage from to 10 volts corresponds 
to steps from to 255, can you write a program that would allow 
you to enter a voltage from the keyboard and that would generate 
this voltage on the meter? Use the following space for your program: 

'! 



We developed the following program, which you may wish to try: 

10 INPUT "VOLTAGE ";V 

20 R = V * 25.5 

30 POKE 49318, R 

40 GOTO 10 

Step 5 

Try your program, too. Does it generate a voltage from the D/ A 
converter that closely matches the voltage that you entered? Our 
program seemed to work well, considering inaccuracies in the meter. 
This program does not have any "error detecting" steps, so you can 
also try and generate a +15- volt signal from the converter. What do 
you think will happen? Will the converter burn out? 
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The converter will not bum out, since it can only accept an 8-bit 
value, which corresponds to an output of +10 volts. The "15" input 
for 15 volts will cause an ILLEGAL QUANTITY ERROR, since we 
are trying to transfer the value 382 to an 8-bit device. It just can't 
be done with eight bits. 

Step 6 

At this point, you should be able to write a program that will al- 
low you to enter an upper voltage and a lower voltage, and to have 
the Apple generate a triangular wave between them. Use your best 
programming skills. 

We used the following program: 

10 INPUT "UPPER VOLTAGE"; H 

20 IF H <= 10 AND H >= THEN 40 

30 PRINT "VOLTAGE OUT OF BOUNDS": GOTO 10 

40 INPUT "LOWER VOLTAGE"; L 

50 IF L <K! 10 AND L >= 

60 PRINT "VOLTAGE OUT OF BOUNDS": GOTO 40 

70 (F H > L THEN 90 

80 PRINT "UPPER V MUST BE HIGHER THAN LOWER V": GOTO 10 

90 H = H * 25.5; L = L * 25.5 
100 FOR V = L TO H 
110 POKE 49318, V 
120 NEXT V 

130 FOR V = H-1 TO L+t STEP -1 
140 POKE 49318, V 
150 NEXT V 
160 GOTO 100 

Run your program and test it. You should be able to make the meter 
needle "swing" between the upper and lower voltages. You may use 
a time delay, or delays, if you wish to slow the meter movement so 
that you can easily watch it. 

This experiment clearly shows you how a simple D/A converter 
may be interfaced to your computer. The NE5018 used internal 
latches, and much of the analog circuitry has been placed on the 
converter chip. D/A converters find use in applications that require 
the computer to control voltage-dependent devices, such as servo 
motors, amplifiers, etc. 

You will not use the NE50I8 D/A converter again, so you may 
remove it from your breadboard. The SN7402 nor gate chip should 
be retained, but the SN7404 inverter may be removed. Power may 
be turned off. Carefully remove the connections to the +12- and 
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— l^<«olt power siq^plies, so tliat they will not come in contact with 
any of the circuitSi 



EXPERIMENT NO. 12 
OUTPUT POmS, BCUr AND UNARY GODB 

Purpose 

the piiJEpinie d this experiment i$ to eiplore the use of an SN74- 

m m imtput port. 

Dlscimlmt 

Newer intimated circuits, such as the Sll?4LS3t3 (xtd li^i, sate 
available to simplify the task of output-port cpiMtruction. In this 
experiment, you will construct an 8-bit output port using one of 
these chips, and use of hhis^'Coded decimal numbers vnSl be 
explored. 

Pin Configaralioti of ihe Inl^BirsrKl arcwit (Fig. 6-14) 
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Fig. 6-14. SN74LS373 cclal latch chip pin cenflgurition. 



Step 1 

Wire the circuit shown in Fig, 6-15. You msy me oolput "C" 
pin 13, on file nor gate circnft ^own tn Fig. 0»l m Sws 'W' lopafi 
to the SN74LS373 chip. If this nor gate circoit is n*rt wfeed tm 
your breadboard, refer to Experiment No. 2. 

Step 2 

Note that the SN74LS373 chip has two control inputs, G and OC. 
The G input controls the latch, and the OC input controls the latch 
outputs, which Eure three-state. Thus, the latch may be used not only 
to obtain information from a bus, but to pass it on to another bus, 
m well. Tk6 TfSsMomM]^ <^ ihe sigoals ate skomi in TaMe 



119 



+ 5 GNO 



Uo ho 



3 


D Q 

OC 

6 


2 


LAMP 

MONITORS 


4 


5 


7 


6 


e 


S 


13 


\z 


K 


15 


1 J 


IS 


18 


19 


1 1 




SN74LS373 



Fig, 6-15. Using SN741S373 octal latch cKip as eufput port. 



Table 6-3. C«ntrol Signal Truth Table for the SN74LS373 



Output Control 


Enable (G) 


Data 


Output 


L 


H 


H 
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L 
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Qo 


H 


X 


X 


Z 



When the Output Control ( OC ) signal is a logic one, the outputs 
have been disabled, or placed in the high-impedance state ( HI-Z ) . 
When the enable or Gating input (G) is a logic one, the informa- 
tion present at the D inputs is passed through the latch circuits to 
the Q outputs. This is the same type of operation that was observed 
for the SN7475 latch chip. 

In this experiment, the OC input should be grounded (logic zero), 
so that the outputs are always enabled. 

Step 3 

Once the output port has been wired, test it by writing a short 
program that will take values from the keyboard and display them 
in binary at the output port. A binary incrementing-count program 
can also be used to test the port. You should be able to write pro- 
grams such as these without any further assistance. 

Step 4 

Enter the following program into your computer and run it. 

10 FOR C = TO 255 

20 POKE 49318, C 

30 FOR T = TO 500: NEXT T 

40 NEXT C 

50 GOTO 10 

1M 



what do you observe at the LEDs? 



You should see a slowly incrementing binary count. You may in- 
crease the length of the time delay at line 30, if you wish. 

Now that the LEDs are displaying an increasing binary count, 
carefully remove the connection between the OC pin, pin 1, on the 
SN74LS373 chip and ground. What happens to the display, or 
LEDs? When you replace this connection, what do you observe? 



In our set of LEDs, all of the LEDs became unlit when the con- 
nection wa.s removed. When the OC input pin was again grounded, 
the count was found to be continuing. The Output Control signal 
did not affect the count. Even though the outputs were disabled and 
placed into their high-impedance state, the counting continued, and 
the latches were "updated" with new information by the computer. 
In our system, the high-impedance state of the outputs caused the 
LEDs to be turned off. This may be different from your observations, 
but you should see that the latch outputs change dramatically when 
the OC input pin is not at ground. 

The SN74LS373 chip is called a three-state octal latch chip, since 
it has three-state outputs on eight latch functions. This chip is par- 
ticularly useful in computer interface circuits, since it contains all 
eight latches, and since its outputs may be placed in the high-imped- 
ance state. The SN74LS373 can be used in complex interfaces that 
are connected to several different computer buses. In fact, the SN- 
74LS373 could be used as part of a communication circuit that could 
link two or more computers. 

Step 5 

Now that you have another input port wired on your breadboard, 
we will use it to further explore some of the manipulations that can 
be performed by the Apple. In past examples, we have used the 
computer to control an incrementing binary count. This is not the 
only code that is in digital electronic equipment. Another popular 
code is the binary-coded decimal format, in which decimal digits 
are each assigned their own binary code, independent of the other 
digits. Of course, this code is still "binary," in the sense that only 
two states are possible for each bit. For example, the decimal num- 
ber 9530 would be represented as 1001 0101 0011 0000 in binary- 
coded decimal, or bed. Note the separation between each set of 
four bits. One set of four bits is used to represent the decimal digit 
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for each decade. The bed code is used in many electronic devices, 
and is used to control seven-segment displays and other decimally 
oriented devices. 

We would like you to try and write a program that will "spUt" a 
number into its bed equivalents. The output port will be used to 
display the different groups, two bed digits at a time. The ten's and 
one's bed digits should be displayed at the output port first, followed 
by the thousand's and hundred's bed digits. You may use the RE- 
TURN, or other key to "stop" the computer between displays of 
the digits. 



We used the following program: 



10 INPUT "VAlUE A 

20 IF A < 10000 THEN 30 ELSE 10 

30 GOSUB 1000 

40 POKE 49318, A + C 

50 GET A$:A = B 

60 GOSUB 1000 

70 POKE 49318, A + C 

80 GOTO 10 



1000 8 = 0; C = 

1010 IF A > 99 THEN 1100 

tO20 tF A < 10 THEN RETURN 

1030 C = C+16: A = A-10 

1040 GOTO 1020 

1100 A = A-lOO; B = B+1 

1110 GOTO 1010 



In the subroutine, the variables are A, B, and C. In this case, the 
A represents the decimal value to be converted to bed (the starting 
value), B represents the "hundreds," while C represents the "tens." 



At the end of the subroutine, A represents the units, or "ones." You 
could have used a new variable for this purpose, if you vi'ished. 

In some cases, it may be difficult for you to remember that you 
are tricking the Apple into generating bed values for you, since you 
are really interested in the binary codes that are being output to 
the port. Thus, while you have tricked the Apple into outputting 
the binary pattern 10011001, vifhich represents 99 in bed, the Apple 
really thinks that it is outputting a decimal 153, which is the num- 
ber that causes the binary pattern, 10011001, to appear on the LEDs. 
There are many different ways in which you can "fool" the com- 
puter into working with odd codes, or codes that do not match the 
ones that it normally uses. 

If you are going to go on to further experiments, you may want 
to leave the SN74LS373 output port on your breadboard. However, 
if you already have another output port already available, the SN- 
74LS373 circuit may be removed. Power may be turned o£E. 

EXPERIMENT NO. 13 
OUTPUT-PORTS TRAFFIC-IIGHT CONTROLLER 

Purpose 

The purpose of this experiment is to show you how the Apple 
computer may be used as a controller in a real application. 

Discussion 

While the control of a traffic light may not seem like a realistic 
problem for us to tackle with the computer, it does illustrate the 
ability of the computer to make decisions and control external 
events. 

Step 1 

An 8-bit output port will be used in this experiment. If you have 
one already connected to your computer, you can use it as long as 
it can control some LEDs. If you have completed one of the output 
port experiments, you may use one of the output port circuits used 
in the experiment. If you need to construct an output port, we refer 
you to Experiment No. 8. 

Lamp monitors or individual LEDs may be used to simulate the 
lamps of the trafiBc light. Only six LEDs are needed, since the north- 
south and east-west lamps would be the same, with a red, yellow, 
and green lamp for each. We used colored LEDs and we adopted 
the following convention; 
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UT LED 

DO RED ^ 

D1 YELLOW > ELM 

02 GREEN j 

Step 2 

You must now determine the patterns of logic ones and zeros that 
are required to turn the individual LEDs on or off. In our circuit, 
the latch chips were used to drive the LEDs directly, and a zero 
turned a LED on, while a one turned a LED off. What values are 
you going to use to turn the various LEDs on and off? 



BIT LED 

D3 RED 1 

D4 YELLOW > MAIN 

D5 GREEN J 



We found that the following binary values were needed. The deci- 
mal equivalents have also been provided for you. 

ELM Red 254 11111110 MAIN Red 247 11110111 
ELM Yellow 253 lIllllOl MAIN Yellow 239 11101111 
ELM Green 251 11111011 MAIN Green 223 11011111 

Step 3 

To start the trafiic-light control operation, write a program that 
will flash the yellow light on Main Street and the red light on Elm 
Street; one second on and one second off. What is the "on" pattern, 
and what is the "off" pattern? 



The off pattern is 255, or all logic ones, while the on pattern has 
bits D4 and DO both as logic zeros, or 238io. We used the following 
program: 

10 POKE 49318,255 

20 FOR T = TO 770: NEXT T 

30 POKE 49318,238 

40 FOR T = TO 770: NEXT T 

50 GOTO 10 
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step 4 

Determine the lamp patterns that will be required for normal 
traflBc light operation. How many are used? What are they? How can 
they be stored in the computer? 



There are only four patterns. They are (a) red on Elm, green on 
Main (222), (b) red on Elm, yellow on Main (238), (c) green on 
Elm, red on Main (243), and (d) yellow on Elm, red on Main (245). 
The values could be stored through the use of DATA statements, 
subscripted variables, or just as variables, one per lamp pattern. 

Step 5 

In the remainder of this experiment, we will assume a "yellow 
period" of two seconds. Thus, if Elm Street is on a 10-second period, 
the green light will be on for 10 seconds, followed by a 2-second 
yellow, before the signal goes to red. 

Write a program that will allow you to sequence through the 
hght patterns, with a 6-second period on Elm and a 10-second pe- 
riod on Main Street. 



We used the following program: 

10 M = 10: E = 6: P = 49318 

20 DATA 222, 238, 243, 245 

30 READ L 

40 POKE P,L 

50 FOR R = 1 TO Nl 
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60 FOR T = O m TTBi HEX.! T 
70 NEXT R 

90 POKE P,L 

100 005UB 10«^ 

m ftCA0 I 

120 POKC P,l 

130 FOR R = 1 TP E 

140 FOR T = O TO 370: NEXT T 

150 NEXT R 

160 READ L 

170 POKE P,L 

180 GOSUB lOOO 

190 RESTORE 

■ 200 GOTO 30 

1000 FOR R = 1 TO 2 
1010 FOR T = TO mis NEXT T 
1020 NEXT R 
RETURN 

WMfes program listed flie previous step wfitt t^jmite cor- 
rectly, many of the steps are repetitive. Could you suggest a new 
program that could be written in a simpler way? How would you 
siixg^lify the prograna? 



]^ program in Step 5, the only changes in the four basic sections 
ol the program are to tteftai m£ the light patterns. By us- 

ing an array of values, one simple loop may be. usskI. We found that 
&e following program worked well: 



10 A(l) = 222: A(2) = 238: A(3) = 243: A(4) = 245 

20 M(l) = 0: M(2) = 2: M(3) = Of lA^ 2 

30 INPUT "AAAfN DELAY "; M(l) 

40 INPUT "ElM DELAY M(3) 

SO FOR Q ^ 1 TO 4 

ea POKE ^1^ 

70 FOR R = 1 TO 

m FOR T = TQ 770! NEXT T 

. 9a N^T R 

.1410 NEXT Q 

lio GOTO SO 



fa. this new program, the A anay stores the light patterns, while the 
M amy stents the time interval. 

Sftftp 7 

So far, the computer has served only as a sequencer, generating 
the proper lamp paftenis and time delays. In this step, some control 
steps will be added to (he traffic-light control program. 

The traffic on Main Street is usually heavy, so the normal mode 
for the traffic hght should be green on Main and red on Elm. The 
program should be alife to diteitf a liEftgle ear waiting oft l3m, so 
that it may be given the green hght. Howovcr, Main Street must 
be given at least 30 seconds of "green time," before any cars are 
sensed on Mm ^^t. TMs 'timm ftat every wiaMag oa llsi 
Street will not automatically trigger a green-on-Elm sequence. To 
make things even more interesting, there is a sensor on Main Street, 
too. If five or more cars are waiting on Main Street at a red light. 
Main Street will be given the j^:eeii light, and tlie ctus on Elm wUl 
have to wait. 

In order to program this, you may wish to draw a simple flowchart 
of the problem. An input port could be used to simulate the two road 
sensors, but to teach you a bit more sAkxeA tibe Apple, the keyboard 
will be used instead. 

The keyboard uses two memory addbes^ for control. Address 
481^ coiitBins l3ie keyboard data, and address 491^ is used as a 
flag-clear pulse output. 

Enter the following program into your computer and run it; 

2000 PKINT PEEK(4915j^ GOTO 2Q0Q 

Press some of the keys on the keyboard and note wlmt he^pt^ on 
the display. What do you observe? 



There is a new decimal va3ue displayed whenever a new key is 
pressed, and the value continues to be displayed until a new key 
is actuated. Thus, the information at ii^ut port 49152 represents the 
@3jie elHSie lasi ie^ that wis psessed. 

Stops 

We w«3tild Mie to have the computer ii^t a value from the Icey- 
board input port only when a key has been pressed. To do this, you 
must use the keyboard flag bit, which is bit D7 at input port 49152. 
If this bit is a logic zero, all values from this port will be less than 128. 
If this bit is a logic one, the values wUl be 128 or greater, up to 255. 

tm 



Thus, by testing the value input from the input port, you can deter- 
mine if a key has been pressed. Of course, after a key is "detected," 
you must reset the flag bit, with a read operation to address 49168. 
Enter the following program into your computer and run it: 

2OO0 tF PEEK(49152) >= 128 THEN PRINT PEEK(49152) 
2010 Z = PEEK(49)68) 
2020 GOTO 2000 

Now press some of the keys, one at a time. What is displayed? Is the 
decimal code for each key displayed as you press it? 



You have probably found that some keys are "missed," once in a 
while. Since the keyboard flag is cleared during every pass through 
the loop, it is possible to have the Apple clear a keyboard flag before 
it is detected. You would really want to have the flag cleared only 
after a key has been detected. 

Step 9 

Write a short keyboard control program that will detect every 
key, only once, and print its decimal equivalent. 



We used the following program that constantly checked the key- 
board, but which only printed a character when the flag was set, 
and only then cleared the keyboard flag. 

2000 IF PEEK(49152) < 128 GOTO 20OO 
2010 PRINT PEEK(49152) 
2020 Z = PEEK(491«3) 
2030 GOTO 2000 

Note that the variable, Z, is a dummy variable, provided simply so 
that the keyboard flag may be cleared with the PEEK (49168) com- 
mand. 

If you want to use the decimal value for a key, without the flag 
bit, simply subtract 128. 

Step 10 

Write your traffic-light controller program and test it, using the 
"E" key as the Elm Street sensor, and the "M" key as the Main Street 
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codes. 

We used approximate^ lO^sectmd periods, for test purposes, with 
^^ectmd yeOow^iiods. The progiBm tii&t we used is listed for yon: 

TO A - oi t> = mvn 

ao PQ KiP, 383 

30 F@t R <- O W 10 

40 WOR T = TO 770i NBtT T 

SO mcT R 

60 IF {«Hi®*ji^ 1^ mm m 

70 GOTO tiO 

so z » PB^ei^iN^ tmm % m&. 
90 FOR R' - i m t 

100 FOR T t- # W S» Wlitt T 

110 tmtn 

\m I^KE P, 343 

130 FOR R » TO TOeO 

ISO IP PEEK(49]52) - «aS TWl IIH 

iii» (46(1 R 

f«0 (SOTO 210 

140 Z = PEEKC49168): A ^ A4-i 
200 IF A < 5 THEN 170 

210 POKE P, 245 

220 FOR R = 1 TO 2 

230 FOR T = TO 770: NEXT T 

240 NEXT R 

3S0 OGTQ 10 

You should note that the keyboard flag is reset before it is tested at 
line 60. This cl^ais any keyboard entriiK that are made during the 
ftr^ iO^sewjinl psdbA. f oa cau rmtt^. ^ #ep, if you twint this 
Elm Street semsf»r Is? ^resW^b^' ttty ©Ws that trip it during tills 
period. 

The flag-detecting step at line 150 has been embedded in the over- 
all timing loop. This means that the flag is always being checked, 
and tliat these flag-detecting steps must be figured into the overall 
delay period. You can do this by testing various values of ^ delay 
cnnstant at line 130. 

There are many c^et #te^ #ds program could do. For ex- 
ample, many intersections have p^be^^bciajx control signals, left-hand 
turn signals, flashing lights, and otlier special features. You could 
tailte ibe pretgfiim as complex as you wish. In this situation, the 
timing is not particularly critical. It wouldn't really matter if the 
cars had to wait an extra second or two while a flag is tested. How- 
ever, periods of 10 or 20 seconds could be annoying to drivers. Keep 
this in mind as yoii pn^^giajpa, la soiac! cases, the time requirements 
^dll be so strict, and ib@ ttai fse^e^ io short, that assembly-laB- 
gas^e programming is dfi^ated. 
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The six LEDs should be removed from the breadboard, but the 
output port should be retained, since you will use it in the next ex- 
periment. Power may be turned off. 



EXPERIMENT NO. 14 
LOGIC-DEVICE TESTER 

Purpose 

The purpose of this experiment is to show you how the computer 
can be used to test an electronic device. In this case, simple gates 
are u,sed. 



Discussion 

Most logic chips that contain gates may be tested by applying 
knovra logic levels to their inputs and then comparing the outputs 
with the truth-table for the device being tested. In this experiment, 
the computer will be used in such a manner. One input port and one 
output port are required. Various devices, such as SN7400, SN7402, 
SN740S, etc., may be tested. The test is a functional test, and not 
a test for dynamic properties, such as switching time, propagation 
delay, and other parameters. 



Step 1 

You will need to construct an input port and an output port for 
use in this experiment. You should be able to construct such ports 
without further assistance. Many of the previous experiments have 
detailed this for you. You may wish to use an SN74LS373 chip as 
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SN7400 OUAD 2-INPUT NANO 




Fig. 6-16. Schematic for the SN7400 NAND gata test circuit. 



the input port. When these ports have been constructed and tested, 
go on to the nert step. 

Step 2 

The test configuration for an SN7400 NAND-gate package is shown 
in Fig. 6-16. For the pin configuration of other chips, we refer you 
to Fig. 6-17. 




SN7408 SN7410 



ycC NG H G NC NC ¥ 



A 6 C E F QUO 

SN743a 



1A IB 1^ ZA lb 2V GNO 

SN7486 



Fig. &-1 7. Pin eenfiguratiant «f som* itandsrd gates. 

Wire the test circuit as shown in Fig. 6-16. Remember to connect 
the +5-volt and ground inputs to both the interface chips and to the 
circuit that is to be tested. The unused inputs at the input port should 
be grounded. 
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YcKi iSmii. be ffble to d^v^Oj^ ^ ^ifilii iables for the various 
gates shown in Fig. 6-17, starting ^Kil|l :||te nand gate. For a two- 
input gate, there are only four coml^^ciill^iis of inputs. How many 
combinations would ^tu^ £pr £crar gates in a sin^ integiated 
me(M package? 



Bfesibly you said 16 comblna'Htins, four for each of the four gates, 
Cef ^6 combinations, the number possible with eight liinary inputs. 
Actually, there are only four meaningful combinations, since all of 
the gates are tested at tiie same ttoie. Knowing that one gate is bad 
for one particular combination of inputs does not serve much pur- 
pose. If one gate is bad, then the entire "package" is bad. 

Step 3 

What are the four combinations of eight bits that will be used at 
the output port to test the nand gate? You should write down bofli 
the dednud and binary vahies for these numbers. 



00 


CO 


m 


00 







01 


01 


01 


01 




85 


10 


10 


10 


10 




170 


11 


n 


11 


11 




255 



Since ^ OSdp^ bive been cormected to input bits D3-D0, we 
would expect them to be all ones or all zeros, that is or 15, de- 
pending upon the test pattern. To "remove" the unused bits, D7-D4, 
we have grounded them. What |^ Ihey be when they are input? 
Will this affect the results? Can you suggest another way of "re- 
moving" these bits from the test data? 



im im^ fis its^ mmsi sm4 ishodk) not affect the 
data. If the bits are not grotmded, a logical and operation could be 
used to mask them. The assembly-language subroutine could be 
used. 

Stop 4 

Develop a short program that will test the nand gate that you 
have interfaced. Yom: ptipmm may^ clo^ly resemble the traffic-light 
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control program shown in Experiment No. 13, Step 6, The program 
does not have to be very complex. 
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! The following program worked quite well in this application: 

10 T(l) = 0: T(2) = 85! T(3) = 170: T(4) = 255 
20 R(l) = IS: R(2) = 15: R(3) =15: R(4) =0 
30 FOR S =1 TO 4 
40 POKE 49318, T(S) 
50 IF PEEK{49319) <> R(S) THEN 100 
• 60 NEXT S 

70 PRINT "TEST OK": END 
100 PRINT "FAILURE": END 

I 

j Step 5 

I Since the pin configurations for the SN7400, SN7408 and SN7486 

are equivalent, that is, inputs and outputs are at the .same positions 
on the chips, could a generalized test program be developed for 
them? How? 



Yes, a generalized test program could be developed so that the user 
could enter the device name, while the computer set up the appro- 
priate truth-table information to be used in the tests. The truth ta- 
bles are provided in Table 6-4. 

You should note that the test patterns are all the same, only the 
results change. 

We used the following test program: 



f oMe 6-4. Truth Tablet for the NAND, AND, and EXOR Gates 



SN7400 
A B OUT 


SN740e 
A B OUT 


SN7486 
A B OUT 


1 

1 1 

1 1 
1 1 




1 

1 

1 1 1 




1 1 

1 1 
1 1 
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TO INPUT "LAST TWO DIGITS ";A$ 
20 IF A$ = "00" THEN 200 
30 IF At = "08" THEN 300 
40 IF A$ = "86" THEN 40O 
50 PRINT "TEST NOT AVAILABLE": GOTO 10 
60 T(1) = 0: T(2) = 85: T(3) = T70: T(4) - 255 
70 FOR S = 1 TO 4 
80 POKE 49318, T(SJ 
90 IF PEEK(49319) <> R(S) THEN 120 
100 NEXT S 

110 PRINT 'TEST OF SN74";A$;" OK":END 
120 PRINT "FAILURE": END 

200 R(l) = IS: R(2) = 15; R(3} = 15: R(4) = 
210 GOTO 60 

300 R(!) = 0: fi{2) = 0: R(3) = 0: I!(4) = 15 
310 GOTO 60 

400 R(l) = 0; R(2) = 15: R<3) = 15: R(4) = 
410 GOTO 60 

The last two digits that are requested by the program are the last 
two digits in the device number; that is, 00 for SN7400, 08 for SN- 
7408, and so on. If several SN7400, SN7408 or SN7486 chips are 
available, you may wish to test these devices. You may wish to re- 
move an input or an output connection to simulate a fault to check 
the interface and your program. 



It should also be possible for the computer to test logic devices 
such as flip-flops and counters. If you are familiar vidth the SN7493 
4-bit binary counter, you may wish to try the following steps. If not, 
you may find it worthwhile to read through these steps. 

The pin configuration and schematic diagram for the SN7493 
counter are provided in Fig. 6-18. In order to test this device, the 
counter outputs must be available to the computer, and the com- 
puter must be able to reset and clock the counter chip. We will not 
try to test the counter exhaustively, but we will test the abihty to 
reset the counter, and the coimting function. 



Step 6 



A MC Qa OO GM> Ol Ce 




Fig. 6-18. SN7493 4-(Ht counter 
pin configuration. 



njjiininiriiJiinir 

iHfVJ "0(11 HC Vcc NC UK 
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S»ep7 

Wire the SN7493 counter as shown in Fig. 6-19. You will need to 
use the input port and the output port from the previous steps in 
this experiment. You will also need two nor gates, as shown in 
Fig. 6-19. A single SN7402 chip will provide these gates. Do not 
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SN7402 



49317 
WR 



49319 ■ 



INPA 
INPB 
RO 
RO 



■ DO 

■ Di 

■ D2 

■ D3 



TO INPUT 
PORT* 



SN7493 



•GROUND INPUT BITS 07 D4 

Fig. 6>19. Test circuit schematic ut«d to check SN7493 counter chips. 



substitute an SN74L93 counter for the SN7493. Remember to ground 
the unused inputs on the input port. 

Step 8 

Write a short test program that will exercise the reset function 
on the counter, and one that will test the ability of the computer 
to clock the counter and increment its count by one. 



We used the follovdng program: 

10 POKE 49318,0 

20 IF PEEK(49319) > THEN 1000 

30 PRINT "RESET TEST OK" 

40 FOR C = 1 TO 15 

50 POKE -49317, 

60 IF PEEK(49319) <> C THEN 1010 

70 NEXT C 

80 PRINT "COUNT TEST OK": END 

1000 PRINT "RESET FAILURE":END 

1010 PRINT "COUNT FAILURE AT "; Ci END 
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The program first tests the reset and then starts the necessary tests 
to test the ability of the chip to increment its count by one for each 
pulse that is received at the INP A pin. 

Step 9 

This program does not test all 16 counter states. The last count 
from 1111 to 0000 is not tested. Could you change the program to 
take care of this? 

It should not be diflBcuIt for you to add the final test to the program. 
There are several ways in which you could do this. Here is one: 

90 POKE 49317,0 

100 IF PEEK(49319) <> THEN 1010 
110 PRINT "COUNT TEST OK": END 

In this case, a final count has been generated and the "wrap-around" 
count from 1111 to 0000 has been tested. 

The output port will not be used again, so you may remove it 
from your breadboard. The input port will be used again. The power 
may be turned off, since the program will not be used again. 

EXPERIMENT NO. 15 
SIMPLE FLAG CIRCUITS 

Purpose 

The purpose of this experiment is to demonstrate the construction 
and use of simple flag circuits. 

Discussion 

Flags are signals that are used by the computer and I/O devices 
so that their operations are synchronized. Flags are commonly used 
to indicate one of two possible conditions, ready/busy, full/empty, 
hot/ cold, and other combinations that relate the conditions of an 
interface to the computer. Experiment No. 6 illustrated the use of 
input ports to transfer nonnumeric information to the computer. 
This experiment will develop this concept further. An 8-bit input 
port is required in this experiment 
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Pin Configuration of the Integrated Circuit (Fig. 6-20) 




Fig. 6-30. SN7474 dual D-lypa flip-flop chip 
pin configuration. 



Step 1 

An input port will be required in this experiment. You should be 
able to construct an input-port circuit without further instructions. 
Many of the previous experiments have detfdled the construction 
of such ports, and we recommend that you use one of these circuits. 
Once your input port has been wired and tested, go on to the next 
step. 

Step 2 

One of the previous experiments investigated the use of simple 
switches as sensor or flag inputs. This experiment will use flip-flop 
circuits in place of the mechanical switches or jumper wires. Wire 
the circuit shown in Fig, 6-21. 

A jumper wire should be used as the connection between +5 volts 
and the clear input, pin 1, so that you can clear the flag by moving 
the wire from +5 volts to ground and then back to +5 volts. The 
pulser circuit may be a pair of cross-coupled nand gates, or an 
equivalent circuit that will generate "clean" noise-free logic transi- 
tions. This type of function is described in the appendix. 

+ 9 GND 



DO TO INPUT 
PORT 




-•■5 



Fig. 6-21. SimpI* fiip.4top-IUMd flag circuit. 
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step 3 

How would you program the computer so that the logic state at 
bit DO of the input port could be monitored? Assume that there are 
two possible conditions :( a) the other bits are grounded (logic zero), 
or ( b ) the other bits may be used for other flag inputs. 



If the other bits are grounded, then the value from the input port 
will be zero when the flag is cleared, and nonzero when it is set. 
If the other bits are used for flag inputs, then the "unwanted" bits 
must be masted. The masking operation uses the logical and opera- 
tion, so an assembly-language subroutine would have to be used. 

Step 4 

In this case, you will enter the assembly- language program that 
is used to perform the and operation on two data bytes. Follow these 
steps to enter the program: 

1. Press the RESET key and type CALL -151 and press the RE- 
TURN key. The Apple should respond with an asterisk ( * ) 
when it is in the Monitor mode. 

2. Type 0300:00 00 00 48 AD 00 03 2D 01 03 8D 02 03 68 60 Leave 
a space between the two-digit groups as shown. Use 00 for the 
first three values in the program. 

3. Press the RETURN key, type 02FF and press the RETURN 
key three times. Now, check the data shown on the display 
with the information that you entered. 

To test this a.ssembly-language routine, you may use the follow- 
ing program. Since the and operation will use binary numbers, you 
will have to convert your test numbers into binary so that you can 
check the results. 

1000 POKE 10,76: POKE 11,03: POKE 12,03 
1010 INPUT " flAASK BYTE ";M: POKE 768,AA 
1020 INPUT " DATA BYTE ",D: POKE 769,D 
1030 Q = USR(O): PRINT "ANSWER "; PEEK(770) 
1040 GOTO 1010 

If the program does not provide the proper results, re-enter the 
Monitor mode and check the data bytes that you have entered. 



You should realize that the POKE commands in line 1000 are used 
to set up pointer address bytes so that the USR command can "lo- 
cate" the assembly-language subroutine that you entered. We refer 
you to Chapter 4 and to Experiment No. 7 for more information 
about this type of assembly-language subroutine use. 

Step 5 

Now that you have entered the assembly-language program that 
will AND two bytes to yield an 8-bit result, you will use it to test the 
flag bit. What would you use as the mask byte? 



Since the flag is being input to the computer at bit DO, only the 
least-significant bit (LSB) would be "set," so the mask would be 
OOOOOOOI2, or lio. The mask byte is placed in address 768, as you can 
probably tell from the test program in the previous step. 

Sfep 6 

Write a short program that could be used to test the flip-flop flag 
circuit. The Apple should print a "0" if the flag is cleared, or a "1" 
if the flag is set. You can reset the flag manually by moving the 
jumper wire that connects flip-flop pin 1 and +5 volts so that pin I 
is momentarily coimected to ground, 



We used the following program: 

10 POKE 10,76: POKE 11,3: POKE 12,3 

20 POKE 768,1 

30 POKE 769,PEEK(49319) 

40 Z = USR(O) 

50 IF PEEK(770) = THEN 80 

60 PRINT "1" 

70 GOTO 30 

aO PRINT "C" 

90 GOTO 30 

This program seemed to work very well. Could you "invert" the 
program so that a logic would be sensed as the on condition, and 
so that a logic one would be sensed as the off condition? 
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Yes. Simply reverse the commands at lines 60 and 80. You can easily 
"invert" the sense of a flag in software. 

Step 7 

In this step, you will use a short program that will count the 
number of times that the flag is set. Again, the assembly-language 
subroutine will be used. You may wish to add another pulser circuit 
to provide the flag-clearing operation to replace the jumper wire 
between pin 1 on the SN7474 and -1-5 volts. 

Enter the following program and run it: 

10 POKE 10,76: POKE 11,3: POKE 12,3 

20 POKE 768,1 

30 HOME: C = 

40 POKE 769, PE£K{49319) 

50 Z = USH(0) 

60 IF PEEK(770) = THEN 40 

70 C = C-l-1: HTAB 1r VTAB 1: PRINT C 

80 GOTO 40 

Be sure that the flip-flop is cleared before you test the program. 
With the program running, actuate the pulser and set the flip-flop. 
What do you observe? Is this what you expected? 



We found that the count started as soon as the flip-flop was set, and 
that it continued for as long as the flag remained set. Clearing the 
flip-flop stopped the count. What we really wanted was one count 
each time the flip-flop was set. 

Why didn't this happen as expected? The set state of the flip-flop 
continued to be tested and detected by the program. We could not 
reset the flip-flop fast enough by hand to stop the counting at one 
count per pulser actuation, 

Step 8 

In most computer systems, the computer, or the flag-containing 
device clears the flag after it has been detected. To allow your inter- 
face to clear the flip-flop, add the circuit shown in Fig. 6-22. You will 
need an SN7402 NOR-gate chip. Be sure that you wire the -1-5-voIt 
power supply to pin 14, and ground to pin 7, on the SN7402 chip. 
Since the NOR-gate circuit will provide the reset signal for the flip- 
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TO SN7474 PIN 1 



Fig. 6-22. Simple flag-clearing circuit schematic. 

flop, be sure that you remove the wire that was used to connect +5 
volts to pin 1 on the SN7474 flip-flop. 

The circuit shown in Fig. 6-22 will allow you to clear the flip-flop 
with a POKE 49318 command. 

Modify your program so that line 65 is added: 

65 POKE 49318,0 

When this command is executed, the flag will be cleared. Since you 
may not know the state of the flag when you start the program, you 
might want to add a flag-clearing command at the start of the pro- 
gram, too. Now run the program. When the flag is detected, the flag 
is immediately cleared. Then the count is incremented and dis- 
played. 

One of the benefits of using this type of flag, and using the assem- 
bly-language subroutine to check the flag, is that you do not "stall" 
the computer waiting for a flag, unless you want to, Thus, you can 
write a program to check for a flag. If the flag is not present, the 
computer goes about some other task. If the flag is set, the device 
associated with it is serviced, and the computer then goes on. 

The BASIC interpreter in the Apple has a flag-checking command 
called WAIT. This command may be used to test for a flag, but if 
the flag is not found, the program continues to wait for it, and it 
cannot do anything else. If a program "hangs up" waiting for a flag 
that never occurs, you must press the RESET key to re-establLsh 
control of the Apple. We refer you to Basic Programming Reference 
Manual for the Apple for more information about the WAIT com- 
mand. This command does not incorporate any flag-clearing com- 
mands. 

EXPERIMENT NO. 16 
A SIMPLE ANALOG-TO-DIGITAL CONVERTER 

Purpose 

In this experiment, you will interface an 8-bit analog-to-digital 
converter to the computer. Several different types of measurements 
will be made. 

Discussion 

There are many applications for analog-to-digital converters, or 
A/D converters in computer systems. The A/D converters allow the 
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doniputer to measure analog voltages such as those thadt would ^^ise 
jErom various signal soxirces and transducers, la tilths tsxpe0m&^ ft 
simple 8-bit A/D converter will be used. The converter is a Ka^tOlfd 
Semiconductor ADC0804-type converter. This converter la& tillcee- 
iM6 otx^ptt^, so^ ft ma be itm^ai^ diteeeay fed a imet&Gmspe^ 
data bus without difficulty. However, the three-state outputs have 
an access time that can be as long as 200 nanoseconds. Thus, if you 
attempt to use the ADC0804 A/D converter on your interface bread- 
board, you will find that the additional time recjuired to actuate the 
bus interlocking circuitry to turn the data bus around for input will 
be too long. Hie data from the mm&^t mil be "mfssed" by tbe 
computer. 

In order to perform this #i(perimextt, you must have acce^ to the 
%mer iipple da£Ei hm. TMs is explasoed in the following steps. 

Pin Csnfiganiflon of tlra! IntegrtfiHl Cfot^lr (Fig, 6>23) 



Dual-In- Liiw Package 



Fig. ^33. Pin eonfigantien of th* ADOIMM cuia—l 
A/D 




Step 1 

In this experiment, you will interface the ADC0804 A/D converter 
directly to the data bus as it comes from the Apple. To do this, care- 
fully remove the two 8216 bus haSex chips at IC-IO and IC-11 on 
your inter&uie breadboard. 

Step 2 

Witts liie ADO0S(M iiitepi^ tStaSt as shown fa Mg. 6^24. Tke 
data bus lines are placed MO: &e corresponding holes at the sockets 
for IC-10 and IC-11. If the wires do not fit into the holes very easily, 
we suggest placing a 16-pin socket with hac^s fieeess holes id ifie 
sockets at IC-10 and IC-11. This will allow you to make the connec- 
tions without having to force the wires in the small holes. The wires 
should fit into the cowesponding holes without much force. If exces- 
sive force is used, you w^y hend the socket contacts so that they 
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Fig. 6-24. ADC0S04 Interface circuit scheinatk. 

do not make proper contact with the 8216 chips when they are re- 
inserted into their respective sockets. 

Step 3 

Enter the following program into your computer and run it: 

10 POKE 49319,0 

20 FOR T = TO 100: NEXT T 

30 PRINT PEEK(49319) 

40 GOTO 10 



What does the program do? What is displayed on the video screen? 



The program exercises the A/D converter, starting a conversion, pro- 
viding a time delay so that the conversion can be performed, and 
then reading and displaying the data. Slowly adjust the potentiom- 
eter as you observe the data to confirm that the converter is oper- 
ating. 

As you change the voltage setting of the potentiometer, you should 
see a corresponding change in the value displayed by the Apple. 
What is the minimum value? What is the maximum value? Does this 
seem to be what you would expect? 
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The minimum value should be in the range of or 1. The maximum 
value should be between 253 and 255, This is what is expected from 
an 8-bit device, since it can only generate values between and 255. 

Step 4 

The ADC0804 chip has a flag output that can be used to monitor 
the status of the converter; that is, busy or ready. This output is a 
logic zero when data is ready for the computer, and it is a logic one 
when the converter is performing a conversion. This output is really 
the output of a flag circuit, and the flag is reset when the eight data 
bits are read into the computer. Since the converter can perform 
many thousands of conversions in a second, is there any need to 
monitor this flag signal? 



Probably not, since the converter will complete the conversion pro- 
cess before the data can be accessed by a BASIC-Ianguage program. 
Can you suggest some possible uses for the flag output? 



The flag could be used for assembly-language A/D converter pro- 
gramming. In assembly-language programs, the flag could be tested 
as an input to an input port, or it could be used with the interrupt 
on the 6502 microprocessor chip. Since these are high-speed appli- 
cations, it would be useful to monitor the flag to determine when the 
converter had finished a conversion. 

Step 5 

Remove line 20 from your program and run the program. What do 
you find? 



The data values are the same as those observed when the program 
was used with the time delay steps. Thus, the converter is "outrun- 
ning" the BASIC control program. 

Step 6 

The values displayed on the screen do not represent the actual 
voltage that is being measured, but are an 8-bit binary representa- 
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tion. Write a program that will perform the conversion to voltages. 
You may add the steps to the program abeady in use. 



We used the follovi'ing steps which simply perform a mathematical 
conversion of the decimal value to 255 to a corresponding voltage 
to +5 volts, 

TO POKE 49319,0 
20 FOR T = TO TOO: NEXT T 
30 PRINT (PEEK(49319)*S/255) 
40 GOTO 10 

Try our program, or your own. Does it work? 



It should. You will see that the computer prints many decimal digits, 
probably too many, since the converter is only accurate to a maxi- 
mum of one part in 256, or about 0.25%. Unfortunately, rounding 
is not a trivial task in the Apple, You can perform either a mathe- 
matical rounding, or you can use a string operation to print only a 
selected number of digits after the decimal point. You can use the 
following if you wish: 

30 A$ = STRS(PEEK(49319} + 5/255) 
40 PRINT LEFT$ (A$,4) 
50 GOTO 10 

Remember that this routine simply limits the displayed value to four 
decimal digits. It does not perform any roimding. 

Step 7 

Try to write a routine that will use the high-resolution graphics 
capability of the Apple computer, so that the program will plot the 
voltage values with respect to time. The measurements should be 
taken at a regular time (time-delay program), and a continuous 
line-plot should be drawn. If you are not familiar with the high- 
resolution graphics formats and commands, use the program pro- 
vided below: 

100 HRG: HCOLOR = 3: Yl =0 
110 FOR X = TO 249 
120 POKE 49319,0 

ISt 



130 Y2 = PEEK(493 19)/ 1.594 
UO HPLOT X,Y1 TO X+1, Y2 
150 YI = Y2 
160 NEXT X 
1 70 END 

Try this program. Vary the potentiometer setting as the program is 
running. The plot should appear as the changes are made. A con- 
stant voltage will give you a horizontal hne on the screen. 



Can you suggest a simple experiment that would demonstrate the 
use of the A/ D converter and the graphics program? 



There are several simple experiments that you might Ulce to try. 
Each involves measuring a voltage that is proportional to the physi- 
cal measurement that is being made. For example, you could mea- 
sure the voltage across a photocell in changing light conditions, a 
voltage across a charging capacitor, or a voltage that is proportional 
to temperature. 

Wire the circuit shown in Fig. 6-25. In this circuit, you will use 
the A/D converter and computer to measure a charging voltage 
across a large electrolytic capacitor. 



Use the jumper wire to discharge the capacitor, and leave it in 
place until after you have started the program. Once the program 
is running, remove the jumper to ground. You should see the volt- 
age slowly increase, as the capacitor is charged. Why does the graph 
show the zero-voltage point on the top of the screen, and the high- 
voltage point on the bottom? 



Step 8 



Fig. 6-25. Capacitor-charging 
circuit diagram. 
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The computer plots from the top to the bottom in increasing values, 
so if you want to invert the display, you will have to "invert" the 
values from the converter. This means that you will need to convert 
a zero into 159, and a 159 into a zero. To do this, simply change line 
130 to: 

130 Y2 = 160-{PEEK(49319)/1.594) 



Step 9 

You can also use the A/D converter to measure temperature. An 
LM335 temperature sensor may be used to generate a voltage that 
is proportional to temperature, at a rate of 10 mV/K. The Kelvin 
scale of temperature uses the same units of degrees as the Celsius 
scale, except that 0°C = 273K, Thus, a room temperature of 20°G 
will be the equivalent of 293K, and the LM335 will generate 293 X 
10 mV as its output, or 2.93 volts. 

To measure temperature, wire the circuit shown in Fig. 6-26. 
Be sure that the potentiometer or capacitor-charging circuit is not 
connected to the A/D converter input at the same time as the tem- 
perature sensor. 

You can use the same graphical display program that was used 
in the previous step, but you may wish to add a time-delay step at 
line 155: 

155 FOR T = TO 100: NEXT T 

This wiU delay the display, since the temperature changes will be 
slower than the capacitor-charging voltage changes. 

Run the program, fleat the sensor with your fingers. Do you ob- 
serve any change? What do you expect to see? 
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Fig. 6-26. Schematic for • famperafure-meaturing circgit, and pin configuration for 

LM335 chip. 
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You probably will not see much change, since the display is set up 
for a range of to 500K, as represented by volts to +5 volts from 
the sensor. If you see more than a few "points" increase in the dis- 
play, you have significantly warmed the sensor. You can more readily 
cool the sensor with some moisture, or with a can of freeze-spray that 
is used to cool electronic components. If this is not available, a piece 
of ice can be used to cool the sensor. 

Could you "expand" the display to provide a more useful display 
of the temperature changes? How could you do this? 



There are several ways of "expanding" the display. If you know that 
the temperatures will only vary between 200 and 300K, you could 
change the software so that the display on the screen represented 
voltages between +2 and +3 volts. However, keep in mind that you 
have not increased the resolution of the converter in doing this. 
There will still be the same number of discrete voltage steps in the 
converter's range. You have only expanded the display of these 
values. 

You could also use some other circuits. Operational amplifiers 
could be used to scale the voltage range of +2 to +3 volts to 0-5 
volts, so that the entire temperature range of 200 to 300K would 
generate 0--5 volts. This could be measured by the converter and 
displayed on the screen. Now, the resolution has been increased, 
since the entire 256 different voltages are used in the temperature 
range of interest. 

There is much more to analog-converter interfacing, but we hope 
that this experiment has interested you in the use of these important 
devices. For additional interfacing ideas and techniques, we refer 
you to TRS-80 Interfacing, Book 2, and MicTocomputer-Analog Con- 
verter Software and Hardware Interfacing ( Howard W. Sams & Co., 
Inc., Indianapo!i.s, IN 46263). 

Please note that in this experiment, we generated a reference volt- 
age of -1-2.5 volts by using two 1000-ohm resistors to divide the -f-5- 
volt supply in half. In precision analog- converter applications, a 
-1-2.500-volt reference is used in place of the resistors. We have 
chosen to use the resistors in this experiment because they are in- 
expensive and easy to set up. However, they produce results that 
are not as accurate as would be needed for precision measurements. 
There are many reference devices and circuits available, as noted in 
the references mentioned above. 
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CHAPTER 



On the Bus 



While many readers will be content to perform some of the experi- 
ments in the previous chapter, and go no further with the design and 
development of interfaces, there are others who will be interested 
in developing special-purpose interface circuits that vnll become a 
permanent part of their computer system. This chapter is written for 
this reader. We will describe how you can design special interface 
circuits that can take advantage of many of the built-in features of 
the Apple computer. 

If you want to construct an interface circuit that will be used again 
and again, you will want to construct it on something other than a 
solderless breadboard. Breadboarded circuits take up workspace, 
they are messy and frequently come apart at the worst possible mo- 
ment. The alternative is to construct the interface circuit in some 
permanent form, so that it can be mounted out of harm's way, inside 
the Apple case. 

When the Apple computer was designed, it must have been obvi- 
ous to the engineers that people would be interested in expanding 
the system so that various standard peripherals and nonstandard cir- 
cuits could be added to the computer. Thus, they provided eight fe- 
male edge connectors at the rear of the main printed circuit board, 
so that the important computer signals would be readily available for 
anyone who wanted to use them. You have already used some of 
these signals, since the interface that was described previously plugs 
into one of the available "slots." 

The slots are numbered 0-7, and you can use all but slot 0, which 
has been reserved by the manufacturer for special expansions of the 
computer. Slots 1-7 are available for you to use as you wish. There 
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Tabia 7-1. Apple Bus Signals and Description* 



Pin 


Nam* 


Dttscription 


1 


I/O SELECT 


A logic zero signal, active at slot n, when the computer 






addresses locations CnOOH-CnfFH. Active during $o- 






Not available at slot 0. (10)* 


2-17 


A15-A0 


Buffered address bus lines. (5) 


18 


R/W 


Buffered read/write control signal. (2) 


19 


SYNC 


Video timing synchronization signal. Available only at 






slot 7. (?) 


20 


I/O STROBE 


A logic zero signal, active at all slots when the com- 






puter addresses locations C800H-CFFFH. Active during 






Oo. (4) 


21 


RDY 


Reedy control input to 6502 processor. 


22 


DMA 


Direct-memory access control input. 


23 


INT OUT 


Interrupt daisy chain signal to adjacent slot. 


24 


DMA OUT 


DMA daisy chain signal to adfacent slot. 


25 


+ 5 volfs 


+ 5-volt power supply connection. 500 mA maximum 






available to all cards. 


26 


GND 


System electrical ground. 


27 


DAAA IN 


DMA daisy chain signal to adjacent slot. 


28 


INT IN 


Interrupt daisy chain signal to adjacent slot. 


29 


NMI 


Nonmaskable interrupt input to 6502 chip. Vectors pro- 






cessor to subroutine at 03FBH. 


30 


Tr5 


Maskable interrupt input to 6502 chip. Address of in- 






terrupt subroutine in 03FE and 03FF. 


31 


RES 


Input/ output line. When pulled low, the Apple is reset. 






Interface may monitor or generate a reset. 


32 


inH 


When pulled to a logic zero, all internal ROMs are dis- 






abled. 


33 


-12 V 


— 1 2-volt power supply connection. Total of 200 mA 






available to all cards. 


34 


-5 V 


— 5-voll- power supply connection. Total of 200 mA 






available to all cards. 


35 


COLOR REF 


This 3.580 MHz color reference signal Is only present at 






slot 7. (?) 


36 


7M 


A standard 7.159 MHz reference signal. (2) 


37 


Q3 


A standard 2.046 MHz reference signal. (2) 


33 


$1 


Standard 1.023 MHz microprocessor clock signal. (2) 


39 


USER 1 


Logic zero input. When pulled low, all internal i/O de- 






vices are disabled. 


40 


<f>0 


Standard 1.023 MHz microprocessor clock signal. Com- 






plement of $ 1 . (2) 


41 


DEVICE SELECT 


logic zero signal, one per slot. Active for 16 addresses 






per slot (see Table 7-3). (10) 


42-49 


07-DO 


Buffered data bus signals. (1) 


50 


+ 12 V 


-fl 2-volt power supply connection. Total of 250 mA 






available to all cards. 



"Number in parentheses indicates the number of SN74LS0O-family inputs that each signal can 
drive per interface slot. 



are many companies that sell plug-compatible interfaces, and you 
can plug these into these slots without further ado. 

In Chapter 5, some of the common interface signals were de- 



scribed; the address bus signals, the data bus signals, and some of 
the control signals. There are other useful signals provided at the 
seven available interface edge connectors. The signals are listed and 
described in Table 7-1. 

Since you are already familiar with the data bus and addres.<: bus 
signals, they will not be discussed any further. Some of the other 
signals are important, too, and they can be used to greatly simplify 
the construction of interface circuits. 

INTERFACE CONTROL SIGNALS 

I/O SELECT 

The I/O SELECT signal (pin 1) is active when it is a logic zero, 
as indicated by the "bar" above the same of th e signal. Each of the 
seven available interface slots, 1-7, has its own I/O SELEC T signal, 
thus th is signal may be used to select a specific card. The I/O SE- 
LECT signal for a card slot, n, is active when the address bus lines 
are set at addresses CnOO through CnF F, inclusive. Fo r example, if 
the Apple addresses location C5A B, the I/O SEL ECT signal at slot 
5 will be a logic zero. None of the I/O SELECT signals at the other 
slots will be active at this time. There will also be times when none 
of these s ignals is active. The range of addresses that affect the I/O 
SELECT signals is shown in Table 7-2. 



Table 7-2. I/O SELECT Addrass Allocation* 



Interfaca Slot 


Addrass Rangs 


1 


ClOO-ClFF 


'(9408-49663 


2 


C200-C2FF 


49664-49919 


3 


C30O-C3FF 


4992CH50175 


4 


C400-C4FF 


50176-50431 


$ 


C500-C5FF 


50432-50687 


6 


C600-C6FF 


50688-50943 


7 


C700-C7FF 


50944-51199 



There are a number of possible uses for this signal. Since it is ac- 
tive when the Apple addresses a contiguous block of 256 addresses, 
or one page, the signal could be used to enable a memory chip with 
256 addresses. It could also be used to enable a device address de- 
coder that could address 256 I/O devices. These applications are 
shown in block diagram form in Figs. 7-1 and 7-2. 

You might be wondering why anyone would want to add a block 
of 256 bytes of memory to an Apple computer system, when the 
Apple can easily contain 48K of memory by itself. In some applica- 
tions, it is necessary to have short assembly-language routines that 
can "drive" an interface. The assembly-language programs do their 
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Fig. 7-1. Using I/O SELECT to control a page <>( memory. 

job very efficiently. Such "driver routines" can be placed in read-only 
memory (ROM), and the ROM chip may be used in the interface 
circuit. In this way, the driver routines are a part of the overall inter- 
face, and they are "loaded" when the interface card is plugged in. 
They do not have to be loaded from cassette or disk, and they do not 
take any of the other memory space. 
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Fig. 7-7. Using I/O SELECT ro control a momory address decoder. 



Sometimes an interface will require a small amount of read/ write 
(R/W) m emory for temporary storage. You can also use the I/O 
SELECT line to control a 256-byte block of R/ W memory. 

Remember that each interface slot has its own I/O SELECT sig- 
nal, and each signal is active when the Apple addresses a specific 
"page" of memory. 

I/O ST ROBE 

The I/O STROBE signal is a logic zero signal that is provided at 
all of the interface slots. It is common to all of the connectors, and 
is not specific to any one. This signal will be a logic zero whenever 
the Apple accesses a location within the range C800II to CFFFH, in- 
clusive. Thus, every card will be signalled when the address on the 
address bus is within this range, which covers 2048 addresses, or 2K 
of memory. 

You may use this signal to enable memory chips and I/O devices, 
but you will probably want to further "qualify" this signal by gating 
it with some of the address bus lines, AlO-AO. A simple block dia- 
gram of how this signal could be used is shovni in Fig, 7-3, In this 
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Fig. 7-3. Using i/O STROBE for IK mtmory block control. 



circuit, the I/O STROBE signal has been used to select a IK block 
of ROM on an interface card. The remaining 1024 addresses could 
be divided among the other interfaces as you wish. We urge that you 
use caution in using this signal, however, since you may find that 
some manufacturers have used this line to decode memory and I/O 
device addresses in just this manner. Thus, you may find that you 
have a conflict in addressing between a commercial interface that 
you wish to add to your system, and one that you have already de- 
signed, built, and installed. 



DEVrCE SELECT 



This signal is specific to each interface slot, and it has a range of 
only 16 ad dresses for each slot, as shown in Table 7-3. The DEVICE 
SELECT signal is active in the logic zero state. Since the DEVICE 
SELECT signal is active for only a 16-address block, its use will be 
fairly well limit ed to I/O device ad dressing, as shown in Fig. 7-4. In 
this circuit, the DEVICE SELECT signal has been used to enable a 
4-to- 16-line decoder. If a particular interface has only a single iunc- 
tion , and only requires a single enable signal, you may decide to use 
the DEVICE SELECT signal by itself, without any further decod- 
ing. This is permissible, as long as you realize that the device selected 
in this way will be active at 16 different addresses, COnOH to COnFH, 
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liMwfKa Slot 






C080-C08F 


49280-49295 


] 


C090-C09F 


49296-49311 


3 


V^UAU— v^UAP 


4yj 1 470^/ 


3 


COBO-COBF 


49328-49343 


4 


COCO-COCF 


49344^9359 


5 


CQPO-COOF 


4»60^9375 






49376^9391 


7 




49392hI94(^ 



frrclnsim ksb^c^ the signal sha IkBits pair alttjr in aM &&imt 
functions to the inte^Eaoe, sksold jm ds^aa to isx^gmnd it at a htm 
time. 

ilQand NMT 

These a re th e two interrupt inputs to the 6502 microprocessor 
chip. The IHQ (iutexttiit it)i^Ml»fe, a nd it can l» dis- 

abled by using the appit^p(^^lpP«(RBr!6 ^Wpi. "fbe NMI (nooimisk- 
able interrupt) is always active. 

These interrupt i nput lines are cdimiioii to all of the seven i nter- 
face slots, with the IRQ signal connected at pin 30, and the NMI 
signal connected at pin 29. In most interface circuits, the NMI line 
Would be dedicated t o one peripheral, and that must be recognized, 
no matter what. The IRQ line would be shared among many inter- 
face circuits. Appropriate software steps would be required within 
tfie interrupt service subroutine so that the computer could detee* 
which device had actually r^n^ted the interrupt Each of the intef- 
rupting devices could have a 1-Blt input port that could be read to 
determine the status of its interrupt flag. A typical interrupt flag cir- 
cuit is shown in Fig. 7-5. Notice that tiie flag is cleared under soft- 
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Fig. 7-S. Interrupt flag circuit diagram. 



If this type of a "polled" interrupt is used, with the computer poll- 
ing each of die devices that could have#ei»rated an interrupt, a pri- 
ority can %e est£it)IIshed in the software. Thus, ff tlie computer checks 
the devices in the order A, B, C, and so on, device A has the highest 
priority, since it will be checked first when an interrupt is detected. 

The f nteiftee^ sldis afed have two other interrupt lines that may be 
of interest, depending upon your application. These signals are the 
interrupt input (INT IN) at pin 28, and the interrupt output (INT 
OUT) at pin 13, These signals are usrf t© *3als^' Arfa'* tatts»ap* 
signals form one card to the next. The signals are only connected be- 
tween the interface connectors, as shown in Fig. 7-6. Thus, the INT 
OUT signal on slot 1 is connected to the INT IN signal on slot 2, the 
INT OUT on slot 2 is connected to the INT IN on slot 3, and SO on. 
The INT IN and IN OUT lines are only connected to Qie adiaciat 
interfaw wA '&my det not gOi mf imi^bm. 
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it simple daisy-chained interrupt scheme is shown in Fig. 7-7. The 
lOTfet'^priority inter rupting devices are further down the chain, fur- 
ther from the INT connection to the 6502 microprocessor chip. In 
this circuit, a higher priority device can pass its interrupt request up 
the chain, blpcking any interrupt requests from the lower priority 
de^ees that are further down the ehaiii. Once the higher-priority 
device has been serviced and its interrupt flag has been cleared, it 
will "open" its gate and allow the lower priority interrupt request to 
ffisss Wi t& til© eompntaf. 

As you can see, the computer still needs some way of determining 
which device is generating the interrupt, so that it can select the cor- 
resjgmding ijectemapt ^attiefe $Qbra>u£&i& tkis type of fe^p^ps 
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scKeme is quite complex, and we recommend using the simple inter- 
mpt Hag circuit provided in Fig. f*^ ^betj^ fee sufiRcient for 
most uses. In the daisy-chain configuration, you cannot have "empty," 
or open, slots between interface circuit boards, since this will break 
the INT IN /INT OUT circiiit "chain." Enough said about interrupts. 
For more information, we refer you to Programming Interfacing 
the 6502, With ExperftnefOs (Howarid W. Sams & Co., Inc., Indian- 
apoHs, IN 46268). 

The DMA input is u.sed to allow an external device to address 
memorjr locations without first having to go through the 6502 micro- 
prdce^» litBs, ^ e&mmt Stx^ hm tmrnaftf mms$, m 
DMA. Since several devices could request a direct memory access 
transfer of information, a daisy-chained set of peripherals is possible, 
sij3©e flie interface iistshiare OMA INand DMA OlTTpfasthat eon^ 
neet to the adjacent interface connectors. Direct memory access in- 
terfaces are not trivial design projects, and we recommend that you 
thoroughly understand the operation of the 6502 microprocessor dlip 
and its asSSQciated circuitry before you attempt to use this feature. 

The reset Lne at pin 31^ BEB^iss/^Mlf a bidirectional signal line. 
You can me Ms Ifae to reset ywr hiterface circuits, sfnee it will he 
a logic zero when the Apple i.s reset when power is applied, or when 
the RESET pushbutton is pressed. You can also force the Apple into 
a reset earffiow %f greawlittg^lWs Itee. tf yoa <^to3S®1s0PBse mSsifae 
to reset the Apple from your interface, a high-current open- collector 
gate or buffer must be used to pull the line to ground. An SN7407 
opBQ -r^llector buffer Alp ©ould be used in this type of efreiJif < T%e 
&S i%nal line is ee(fflai(t?ii to all of the interface slots. 

In the Apple computer, you caa substitute f&Gt 0im ass6i«tfe%* 
language programs for the p rograms stored in the BASIC interpreter 
ROMs. By pulling the INH line at pin 32 to ground, you vdll inhibit 
all of the BASIC interpreter and Monitor ROMs, so that your own 
programs can control the entire system. Since there is some f&om 
already available for this type of operation, you probably won't use 
this function, since you would not have access to any of the useful 
suhrbntfittes m^&m standard MM^ sapp'H&i •'^Mi-®^ Afpfei It 
would be diflScult, for example, to control the display, without the 
subroutines in the BASIC interpreter ROMs. You will need an open- 
collector buffer dfei^ t0 pidl &^ toe ft> i^mmAt if ;pa dhoose to i«e 
this funptipn. 
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USER 1 

This input will allow you to inhibi t the generation of all of the 
I/O SELECT and DEVICE SELECT signals within the Apple com- 
puter, so that you can "turn off' all of the I/O devices. This line must 
be pulled down to a logic zero to cause this action. To prevent the 
accidental use of this line, you must use a wire jumper to connect two 
solder pads on the main printed circuit board of the Apple, before 
the USER 1 signal can be used. We refer you to the Apple II Refer- 
ence Manual for the necessary details. 

Since your primary purpose in using the I/O SELECT and DE- 
VICE SELECT signals is to simplify your interface design, there is 
probably no need to use this line, unless you wish to do some sort of 
expansion of the computer system with I/O devices that are external 
to the basic system, or that mi ght use some o f th e memory addresses 
that have been assigned to the I/O SELECT and DEVICE SELECT 
signals. The USER I signal is present at pin 39 on the interface con- 
nectors. 

RDY 

There are times when it is necessary to slightly "delay" the 6502 
microprocessor so that an external I/O device, or memory chip will 
have suflBcient time to access its data and present it on the data bus. 
The ready input (RDY) found at pin 21 on each of the interface con- 
nectors can be used to put the 6502 in a "wait" condition when it is 
grounded. This input must be synchronized with the microprocessor 
clock, and it should change its state during the ^'i clock logic one 
state. The RDY input was used in older 6502-based computers, since 
older memory devices could not access their data as fast as required 
by the computer. Thus, when they were addresses, they had to put 
the 6502 into a "wait" condition for several clock cycles until their 
data was available. We doubt that you will find much use for this 
signal, except in specialized interfaces. 

Clock Signals 

There are six clock signals that are available for interface use. 
These are <l>o, 4>i, Q3, 7M, COLOR REF, and SYNC, The <6o and 
4>i are the main timing clock signals, running at 1 MHz. The clock 
signals are the inverse of one another. These signals are used to co- 
ordinate external I/O operations with the normal flow of data on the 
bus. As sho wn in Fig. 5-12 , the $i signal is used to control the gener- 
ation of the RD and WR signals for externa! I/O devices. The I/O 
SELECT and DEVICE SELECT ^gntds at the I/O connectors have 
already been gated, or "qualified," with the clock signal. 

The Q3 signal is a 2 MHz clock signal that is asymmetric; that is, 
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Fig. 7-S. Timing diagram for virioui Appla clock signals. 

it is not a square wave. The 7M signal is a 7 MHz clock signal that is 
a square wave. The clock signals are derived from the main clock 
circuitry within the Apple, and their timing relationships are shown 
in Fig. 7-8. We refer you to a complete data sheet for the 6502 mi- 
croprocessor for additional information about the 6502 timing rela- 
tionships. 

The COLOR REF and SYNC signals are available only at inter- 
face slot 7. The COLOR REF signal is die 3.5 MHz color reference 
signal generated by the video clock circuit in the Apple. The SYNC 
signal is the video timing synchronization signal. You will probably 
not use these signals in your interface designs unless you will be 
using video control circuits. 

Power 

The interface connectors provide access to four standard voltages 
and to ground. The voltages provided are +12, —12, +5, and —5 
volts. The current for each of these voltages is limited to a few hun- 
dred milliamperes, so you should consider the use of low-power in- 
terface chips, such as those found in the SN74LS0O family. 

Other Considerations 

The bus-driving capability of the interface signals is quite limited, 
with most signals limited to driving only a few SN74LS00-type in- 
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You must be careful in your design that you do not overload 
these signals by expecting them to drive more chip inputs than they 
can. If you need additional power from these signals so that they can 
drive more inputs on an interface card, you must buffer the signals 
ynih appropriate bufier chips. Just keep in mind that the buffers will 
need some additional power from the power supplies, and there is 
not a great deal of "extra" power at the interface connectors . Thus, 
you must balance yom: needs for signal buffering with the available 
ptcuwet. tpt alwttys tise an ettsemal power supply to power 
some of iite Iflifieiiace cards, but this defeats the purpose behind put- 
ting the £allel:^^ circuits in the Apple enclosure in the first place. 

AN INmFAelNe SCAMPLE 

Now that most of the useful interface signals have been described, 
let's take a close look at a typical interface circuit that can be used 
wfth the Apple computer. In many applications, it is necessary for 
the computer to communicate with other devices. These may include 
printers, controllers, remote data acquisition stations, and maybe 
e^er computers. Inmost cases, a form of serial communicaticM 
is so that long lengths of multiconductor cables are not re- 

quited. Ibf ost serial communication schemes use three or foiur wires, 
so {bat tlie iiifbrmatlon that is to be exchanged 1$ fi^snutted in serial 
fashion, bit by bit, ov&c the vnre. One set of wires is used for trans- 
mitting, and the other set is used for receiving. Such communication 
is tmially called asynchronous-serial conmiunication, sin^ is 
laQ OMamon clock signal, or reference, that connects the two systems. 

Most of the microprocessor chip manufacturers have developed 
some type of communication chip for their family of microprocessors. 
In fact, you can even "cross" fanulies, so that a communication chip 
that was developed for the 808OA family can be used with a 650S 
processor. In fact, that is exactly what we plan to do in this example; 
an 8251 imiversal synchronous/ asynchronous receiver-transmitter 
chip wiU be fattmfste^ to #e Apple i^amputer, li^t at the 
dot. We will not pro\'ide you with a ^reat deal of detail about the 
operation of the USART chip, since ftodS has been covered in detail 
in TRS-SO Interfacing, Boefc 2 (HowMd W. Sams & Co., Eac^ Iftdi- 
anapolis, IN 46268 ) . A magazine article covering the subject is also 
available. See "Cross-Pollinating the Apple," Byte, April, 1979, p. 24. 

Since the 8251 USART chip is a bus -compatible chip, it should not 
be too difficult to interface the Apple. A pin configuration and block 
diagram for the USART are provided in Fig. 7-9. You should be able 
to recognize the databus inputs, the RD and WR control inputs and 
a chip select input, CS. Since the USART contains two sets of re^- 
terSj, ^fa^re mxM. be some vmf fA distinguishing bet^e^ &Se^. Ski 
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CONTROL/ DATA input at pin 12 (C/D) performs this function. 
A logic one selects the control mode, or command mode, while a 
logic zero selects the data mode. One of the address bits can be con- 
nected to this input to allow the computer to access each of the inter- 
nal registers by using one address for the command register and an- 
other address for the data register. 

Since the USART will be communicating with other asynchronous- 
serial devices, there are standard data rates that must be used to as- 
sure that the data rates of the transmitting instrument and the receiv- 
ing computer are fairly close. A Motorola MC14411 bit rate generator 
chip has been chosen to perform this function, since it is crystal con- 
trolled. There are other popular clock-generating schemes, too. 

Since the standard logic levels provided by SN7400 family tran- 
sistor-transistor logic (TTL) devices cannot be used to drive long 
communication lines, you will need to choose whether you wish to 
use 20 mA current-loop signals or standard RS-232C control levels. 
The necessary level-conversion circuits are easy to obtain, and they 
are detailed in the references noted previously. 

Since any sort of communication interface is useless without the 
software to drive it, you will need some software routines that can 
drive the USART chip. For the most part, these will be simple, and 
you may wish to use BASIC-language programs for control purposes. 
If you choose to use assembly-language programming, you might 
consider putting your control programs in ROM, and putting the 
ROM right on the interface board. Since there are 256 bytes of ad- 
dress space available for each interface slot, a small ROM can be 
accommodated. The 256-byte space is quite enough for some USART 
control programs. You can use the Monitor to test your assembly- 
language programs before they are put into ROM. 

A complete USART interface is shown in Fig. 7-10. This circuit 
has been wired and tested in our Apple computer. If you wish to use 
this circuit in your computer, we suggest that you obtain the data 
sheets for the 8251 or 8251A USART chip, and the Motorola MC- 
14411 bit-rate generator chip, so that you will understand how they 
work. In Fig. 7-11, we have provided a general addressing circuit for 
a 256-byte block of ROM, which could be used to store the assembly- 
language USART control routines. The actual circuit would depend 
upon the particular ROM chip, or chips that you choose to use. In 
this circuit, Fairchild 93427 ROMs have been used. These are fast, 
bipolar, fusible-link ROMs. Each chip contains 1024 bits, organized 
in 256 4-bit words, so two chips are required for a complete 8-bit 
word. Slow, erasable PROM chips are not recommended, since their 
access times are fairly slow, and they could cause problems. Most of 
these devices contain many more locations than you can use. 

You can build this circuit on a standard interface wire-wrap card, 



or on another type of suitable prototype card that can be plugged 
into one of the available interface slots. If you use the wire-wrap 
prototype technique, you will find that the wire-wrap pins and the 
chips stick out from both sides of the card, making it difiBcult to use 
the adjacent interface slots. 
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Fig. 7-10. Simple USART-to-Apple interface circuit sciieinatic. 



In our computer system, we used the USART interface in slot 3, 
so that the USART was addressed as devices 49328 and 49329. The 
registers at address 49328 are the receiver and transmitter registers, 
while the registers at address 49329 are the control and Bag registers. 
Keep in mind that you can have two registers for each address, since 
one is a write-to register, and the other is a read-from register. If you 
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Fig. 7-11. A !564>yt« mamery expansion circuir diagram. 



moved the card to another interface slot, the addresses for the 
USART would change, as noted in Table 7-3. 

To use the USART interface, you must first initialize the chip with 
some control information that is sent as two consecutive bytes to the 
control register. Don't worry about sending two bytes to the same 
register, the USART "knows" what to do with them. After the 
USART has been initialized, you can use it to transmit and receive 
asynchronous-serial streams of information. The program shown in 
Example 7-1 can be used to transmit an 8-bit byte of data, while the 
program shown in Example 7-2 can be used to receive an 8-bit byte. 

Exampla 7-1. USART Transmittar Conlrel Subroiitin* 

1010 POKE 49328, TX 
1020 WAIT 49329, 1 
1 030 RETURN 

Example 7-2. USART Receiv«r Control Subroutine 

1050 WAIT 49329, 2 
1060 RX = PEEK(4932B) 
1070 RETURN 



The software checks the necessary flags so that the transmitter trans- 
mits its data only when it is ready, and the receiver only provides 
data when it has actually received some. 

The main point here has been to develop a simple interface that 
uses many of the Apple bus interface control signals, so that you can 
see how they work. It is also nice to know that the interface example 
actually works, and that it can be used in some real applications. We 
hope that you have seen how easy it is to develop an interface for 
the Apple, based upon the concepts of port addressing, port control, 
and flags, that we introduced throughout the book. 
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APPENDIX 




Logic Functions 



In the experiments in this book, several logic functions are re- 
quired. These functions are noted as lamp monitors, logic switches, 
and pulsers. In each case, the equivalent circuits are simple, but 
rather than duplicate them in each schematic diagram, block dia- 
grams have been used. The following sections describe each of the 
functions that are required. 



Lamp monitors are simply Ught-emitting diodes, or other on-oflf 
indicating devices that are used to indicate the state of a logical 
output. We have adopted the convention of logic one being the Ut, 
or on state, and logic zero being the unlit, or off, state. The two cir- 
cuits shown in Fig. A-1 may be used to construct lamp monitors. The 



LAMP MONITORS 



LED 



22 



NPUT 




T 6R0UND 



+ 5 



INPUT 




LED ZZO 
2 .... 



7404 or 74 05 



Fig. A-1. Sclwmatict gf Iwa simpU lamp-monitor circuitt thai may be uied 
in •xparimtnli. 
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use of red LEDs is recommended, since they are inexpensive and 
readily seen. You will require at least eight of the individual lamp 
monitors to do the experiments in this book. 

LOGIC SWITCHES 

Logic switches are simply switches that have been configured to 
provide either the logic one or the logic zero voltages to the TTL- 
compatible integrated circuits used in the experiments. A typical 
logic switch is shown in Fig. A-2. A single-pole, single-throw toggle 
switch or slide switch may be used. At least eight of the logic-switch 
circuits will be required in the experiments. 

1000 



Fig. A-2. Schamatk of simple iogic- 
iwilch circuit iKat may be used to 
ganarate logic one or logic 
laro output. 




PUISERS 

The pulsar circuit is used in the experiments to provide "clean" 
outputs that are free of the "bounce" that is normally associated 
with mechanical switches. Since most switches use spring-like metal 
contacts, the contacts will often open and close several times after 
the switch has been opened or closed. If such a mechanical switch 
is used to provide pulses to a counter, up to 30 to 40 pulses may be 
counted, depending on the type of switch used. Since there are many 
cases in which a clean logic one to logic zero, or logic zero to logic 
one, transition is required, a debounced switch is frequently useful. 
Mechanical switches are easily debounced, if they have contacts of 
the single-pole, double-throw form. A typical debouncing circuit is 
shown in Fig. A-3. In this case, two nand gates have been used to 
form a flip-flop that may be set, or reset, by the switch. As shown in 

1000 
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Fig. A-3. Schematic for debounced 
pulser in which "cross-coupled" 
NAND gate has been used to 
eliminate contact bounce. 
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Fig. A-3, two outputs are available. With the switch in the position 
shown, the normal logic states are shown at the outputs of the two 
gates. When the switch is moved to the other position, the outputs 
of the NAND gates will switch. It is suggested that a momentary 
switch be used in the pulser circuits. 

Lamp monitors, logic switches, and pulsers are all useful devices 
when breadboarding logic circuits. While the circuits shown in Figs, 
A-1 through A-3 are simple, you may not wish to build them your- 
self. Several companies produce digital breadboarding devices that 
incorporate lamp monitors, logic switches, and pulsers, as well as 
other digital functions. We suggest that you write to the following 
companies for information about their digital-electronic bread- 
hoarding systems: 

E & L Instruments, Inc. 
61 First Street 
Derby, CT 06418 

AP Products, Inc. 
Mentor, OH 44060 

PACCOM 

14825 NE 40th, Suite 340 
Redmond, WA 98025 
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APPENDIX 



Parts Required for 
the Experiments 

4 SN7402 Quad NOH-gate integrated circuit (IC) 
2 SN7474 dual D-type flip-flop IC 

2 DM8095 or SN74365 three-state input buffer (2@ per input 
port) 

2 SN7475 Quad latch IC 

1 NE5018 eight-bit D/A converter IC (Signetics Corporation) 

1 SN7404 hex inverter IC 

2 SN74LS373 three-state octal latch IC 
1 0.01-/xF, disc ceramic capacitor 

1 4700-ohm, V4-watt resistor 
6 220-ohm, y4-watt resistors 

6 Visible LEDs (2@ red, 2@ green, and 2@ yellow) 

1 lOK, potentiometer trimmer-type 

1 lOK, Vi-watt resistor 

1 lOQ-fjiF electrolytic capacitor 16 WVDC 

1 33K, Vd-watt resistor 

1 150-pF disc capacitor 

1 2200-ohm, ^-watt resistor 

1 ADC0804 analog-to-digital converter (National Semiconductor 
Corp.) 

1 LM335 temperature sensor 
4 1000-ohm, ^4-watt resistors 

l» 



Besides the parts listed, you will need an assortment of SN7400, 
SN7408, SN7402, SN7410, SN7486, SN7430, and SN7493 integrated 
circuits for use in the logic-tester program in Experiment No. 14. We 
suggest that you read through this experiment to determine exactly 
what circuits you will want to test. 

Other useful equipment; a ±12-volt power supply (for use with 
the D/A converter circuit), hook-up wire, an extra solderless bread- 
board, pulsers, logic switches, lamp monitors, and a voltmeter or 
vom. 

Information about the analog converters is available from: 

ADC0804 A/D Converter NE5018 D/A Converter 

National Semiconductor Corp. Signetics Corporation 

2900 Semiconductor Drive 811 East Arques Avenue 

Santa Clara, CA 95051 Sunnyvale, CA 94086 

Integrated circuits and components are available from many man- 
ufacturers, and we suggest that you check the many advertisements 
in the last pages of Radio-Electronics, Popular Electronics, Kilobaud 
Microcomputing, and other electronic magazines. We have tried to 
use standard parts wherever possible. 
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APPENDIX 



6502 Microprocessor 
Technical Data 

The following pages contain some technical information pertain- 
ing to the 6502 microprocessor chip. This information has been ab- 
stracted from the 1980 Component Data Catalog, from MOS Tech- 
nology, Inc., 950 Rittenhouse Rd., Norristown, PA 19403. For more 
complete information about the 6502 processor and its associated 
family of functions, we suggest that you write to the manufacturer 
for a complete data sheet. 

The 6502 chip is also available from: 

Rockwell International Synertek, Inc. 

3310 Miraloma Avenue 3001 Stender Way 

Anaheim, CA 92803 Santa Clara, CA 95051 

These manufacturers can also provide you with information about 
their 6502 microprocessor chip, and related devices. 
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MCS6500 Microprocessors 



• Smgic +5V SuppJf 

• N<lunnet, Sjlicon-Gi(e, Depletkm-LOftrf Technokif y 

• B-BH Paralel Processing 

• 56 Inslnjctioni 

• Decimal «nd Bmary Arithmetic 

CttSCRIPTION 



* 13 Addressing Model 

* Progrvnmabhe Stick Pocnlerand Vvuble^Lcf^ Stadc 

• UsaWe WUh Any Type or Speed Memary 
■ 1 or 3 MHz Operatbn 

• P%wined Architecture 



The MCS6500 Series microprocessors represent the first totaly soHwafe-compatible microprocessor famaly. This family 
o! products Includes a range of software-compalibJe microprocessors which provide a selection of addressable memory 
range, interrupt inpul options and on-chip dock oscillators and drivers. All of the microprocessors in the MCS6500 group 
are software-Compatible within the group and are bus compatrble with ihe M6B00 product offering. 

The family includes five microprocessors with on-board dock osdliators and drivers and four mtcroprocessors driven by 
external clocks, The on-chip cbck versions are aimed at high-performance, low-cost applcatfons where singJe-phase 
jnpuls, crystal or RC inputs provkJe the time b^se. The external cbck veriions are geared for multi-processor system 
appliCdtions where maximum liming control is mary:latorv- AJI versions of the microprocessors are available in 1 MHz and 
2 MHz ('A' suffix on product numbers) maxinujm operating frequencies, 
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WNFwcnoNS 

CkKkt (I'l and *I) 

The MCSfcSIX requires a two-phase, non-overlapping 
dock that runs at the V^^^ voltage level. 

The MCS650X docks are supplied wilii ari internal dock 
generator. The trequency of these clocks is externally con- 
trolled. Details of this feature are discussed in the 
MCS6502 portion of this data sheet. 

A(l(kmBus(A0-AI5) 

(See sections on eacti processor for respectiii* address 
Unes or those devices.) 

These outputs are TTL-compatible, capable of cfriving one 
sUtKlifd TTl load and I30pf. 



Data Bus (DO-D?) 

Eight pins are used for the data bus. This is a tki-directional 
bus, transferring data to and from the device and 
peripherals- The Olitputs are three-state buffers capal^e of 
driving one standard TTL load and 13apF. 

Data Bus Enable <DeE) 

Tfss TTL<0(npatibte input albws external control of the 
three-state data output buffers and will enable the 
microprocessor bus driver when in tfie high state. In nor- 
mal operation, DBE would be driven by the phase two (*2) 
dock, thus aDowing data input from micfop#ocessor only 
dtring 42 Duririg the read cycle. Ihe data bus drivers are 
internilly disatJed. becoming essentially an open circuit. 
To disable data l?us drivers eKtemalty, 06E should be held 
low. 
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RCMtr <ltDY) 

This input signal allows the user to sinftle-cyck the 
microprocessor on all cycles except write cycles. A nega- 
tive' transition to the low state during or coinddeni with 
phaw one (<t1) wil hail Ihe mkroprocessof with the out- 
put adt^ess [inefi re^lect^ng the current address 
fetched. Thii cordbon wil reniain thnx^ a ^Ijwquent 
phdie two {^2) in wNch the Ready li^l is low This 
feature allows microprocessof interfacing with low-^peed 
PROMS as well as fast (max. 2 cyde) Direct Memory Ac- 
cess (DMA). If Ready low durir^ a write cycte, It is 
ignored until the fotlowinfl read operation. 

This TTL-compabble signal requests Ghat an interrupt se- 
quence begin within the microprocessor. The 
microprocesHir wil complete the current instruction being 
executed before recognizing the request. At that tinne, the 
interrupt mask bit in the ^atus Code Regkter will be eKarrv 
ined. \i the interrupt mask flag is not set. the 
microprocessor wil begin an intemjpl sequence, The Pro- 
gram Cokffiter and Proceiior Status Register are stored in 
the stack. The microprocessor wii then set the intemjpt 
mask flag high so that no further riterrupts may occur. At 
the ertd of this cyde, the program counter low wil be 
k>aded from addres FFl^E. and program counter high from 
location FFFF. transferring progran^ control to the memory 
vector k>cated at these addresses. The RDY signal must be 
in the high state tor any interrupt to be recognized. A 3KQ 
external resistor should be used for proper wire-OR 
operatiori. 

Nof^AMable Mem^it 

A negative-going edge on this input requests that a non- 
maskable aiiterrupt sequerKe be generated within the 
mkroprocessof. 

is an uncondtiorul interrupt. Folk>wing corrpletkjn of 
the current instruction, the sequerKe of operatiom de- 
firjed fof wi be perfofmed. regardesi of the state of 
the mtemipl mask flag. The vector address taaded into the 
progrvn counter, kiw and high, are kKations FFFA artd 
FFB respectively, transferring program control to the 
memory vector kKated at these addresses. The instruc- 
tions baded at these kx:ations cause the microprocessor 
to branch to a non-maskable intemjpt routine in memory. 



MM also requres an external iKU renter to V^c for 
proper wire-OR operations- 
Inputs and MMI are hardware interrupts lines that are 
sampled during i2 and wfll begin the approfviate intermpt 
routrrw on the *1 folowing (he COrnpJetion of the current 
nstructicHl. 

Set t^verflow Flag (S.O.) 

A NEGATIVE-going edge on this input sets the overflow bit 
in the Status Code Register This signal is sampled on the 
trailing edge of 4>1. 

SYNC 

This output Krw is provided to fdentrfy (hose cydes during 
which the microprocessor is doing an OP CODE fetch. The 
SYNC line goes high during *1 of an OF CODE fetch and 
stays high for the remainder of that cycle. If the RDY line is 
pulled low during the $1 ckxk pulse in whkh SYNC went 
high, the processor will stop in its current state and will 
remain in the slate untB tfw RDY Jine goes high. In this 
manner, the SYNC signal can be used to control RDY to 
cause single instruaKm execution. 

Resel 

This input is used to reset or start the microprocessor from 
a power down condition. During <he time that this line i^ 
held tow. writing to or from the mkroprcMressor is inhibit- 
ed. When a positive edge is detected on the input, the 
microprocessor wiU immediately begin the reset sequence. 

After a system initialization time ot six clock cyctes, 
the mask internjpt flag will be set and the mkroprocessor 
wiU kud the prc^am counter from memory vector bca- 
\km FTFC arid FFFD. This Is die start kxaton for program 
control. 

After Vcc reaches 4.75 vohs in a power up routine, reset 
must be held low for at least two dock cydes. At th& time 
the R/W and {iYNQ signal wil become vaSd, 

When the reset signal goes high folbwrig these two dock 
cycles, the microprocessor will proceed with the normal 
reset procedire detailed above. 
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WSTBUCnON SET— AlPHABETKAL SKJUENQ 

ADC Add Memory to AccumiJatOf wish Can-v 

AND 'AND' Memory with Accumulator 

ASL Shiit left One Bit (Memory or AccumJator) 

BCC Branch on Orry Clear 

BCS Branch on Cirry Set 

BfQ Branch on Rpsutt Zero 

BIT Test Bits in Memory with Accumiiatof 

BMI Branch on Result Minus 

Bh4£ Branch on Resdt rot Zero 

BPL Branch on Resdt Plu4 

BRK Force Break 

BVC Branch on Overflow Clear 

BV5 Branch on Overflow Set 

CLC Oeaf Carry Flag 

CLD Clear Dedmaf Mode 

CLI Clear Interrupt Disable Bit 

aV Oear Overflow Flag 

CMP Compare A/temory and AccumuJatof 

CPX Compare Memory arxJ bidcK X 

CI*Y Compare Memory and Index Y 

DEC Deaemenl Merr>orv by One 

DEX DecrefTwni kidex X by One 

D£Y Decrement Index Y by One 

EOR txdusive-or' Memory with Accumulator 

NC haemenl Merrmry by Or» 

fNX Inaemens Inden by One 

INV Increment fcideit V by One 

IMP lump to New Location 

JSR jump to New location Savir^g Return Address 

LDA Load Accumulator with Memory 

LDX Load Index X with Memorv 

LDY Load Jndex Y with Memory 

LSR Shift One Btt Right (Memory or Accumulator) 

NOP No Operation 

ORA 'OR' Memory with Accumulator 

PHa Push Accumulator on Stack 

PHP Push Processor Status on Stack 



PLA Pull Accumulator from Stack 

PLP PuH Proce^ior ^atus from Stack 

ROL Rotate One Bit left (Menxjry or Accumulator) 

ROR Rotate One Bit Ri^t (Memory or Accumulator) 

RT1 Return from Interrupt 

RTS Return from Subroutine 

SBC Subtract Memory from Accumufator with Sorrow 

SEC Set Carry Fla« 

SED Set Decimal Mode 

S£l Set Imen^jpt Drsable Status 

STA Store Accumiialor in Memory 

SIX Store tidex X in Memory 

STV Store Index V in Memory 

TAX Transfer Accumulator to Index X 

TAY Trarwfer Accunxilator to Index Y 

TSX Transfer Stack Pointer to Index X 

TXA Tramfer Index X to Accumulator 

TXS Transfer tidex X to Stack Pointer 

TYA Transfer Irriex Y to Accumulator 



ADOfiESStNC MODCS 

Accumulalor Addressing. This form of addressing is repre- 
iented with a one-byte irBtructk^, implying an operalion 
on the accunrrulalor. 



Inmnedule Addrelring. In immediate addressing, the 
operand is conlaried in the second byte of the instruction, 
wKh no further memory adckesMng requred. 

AlHolule AddrcMBTg. k\ absolute addressing, the second 
byie of the mstnjctioo specifies the eight low-ordw bits 
of the effective address while the third byte specifies 
the eight high-order bits. Thus, the absolute addressing 
mode aBows access to the entire f>SK byt^ of addressable 
memory. 

lero Page Adekecnng. The zero page retmctions aBow 
for shorter co<^e and execution times by only fetching the 
second byte of tlie instruction and assuming a zero high- 
address byte. Careful use of the zefQ page can result in 
significant increase in code efficiency. 
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Indexed Zero Page Adikesxing. pc, Y indexing) — This form 
of addressing is used in conjunction with the index register 
arid is referred to as "Zero Page. X' or "Zero Page, Y". The 
effective address is calculated by adding the secorxi bvte 
to the contents of the index register. Since this i5 a form of 
'Zero Page' addressrg, the content of the second byte 
refererv:es a location in page zero. Additionally due to the 
'Zero Page' addressing nature of this mode, no carry is 
added to the high order bits ot memory and crossing of 
page boordarie? does rxM occur. 

Indexed Ahsohilc Adifacfifaig. (X, Y indexing) - This form 
of addressing is used in conjunction with X and Y mdeK 
register and is referred lo as 'Absokite. X", and "Absolule, 
Y". The et^fearve address ts formed by adting the contents 
of X or Y to the address contained in the second and third 
bytes of the instruction. This mode albws the irxJex regs- 
lef to contain the index or count value and the instnjctbn 
to Contain the base address. This type of indexing ^Iqw5 
any location referertdng and the index to modify multiple 
fields resiiting in reduced coding and execubon time. 

hnplwd AddressHig. ki the jmpfied addresscrig mode. :he 
address cooiainr^ the operand e vnpliotly stated 'r\ the 
operation code of the instruction. 

Relative Addressing. Relative add'esstng is used orilr with 
branch instructions and esiab>Jisf«s a destination for the 
conditional branch. The second byte of the Fistrudkjn 
becomes the operand wNch is an offset added to the 
conitents of ?he lower eight bits of the program counter 
when the counter k set at the next instruction. The range 
of the offset is -128 to + 127 byte? from the next instruc- 
tion. 

hHlexed htftrecf Addresfaig. in indexed tn<&ect address- 
ir^ (referred to as Irxiirect, X), the second byte of the 
instruction ts added to tfie contents of the X irxlex register, 
dtscardrig the carry. The result of tNs addtjon points to a 
memory location on page zero whose contents is the tow^ 



order eight bits of the effective address. The next memory 
location in page zero contains the high-order eight bits of 
the effective address. Both memory locations specifying 
the htgh and low-order bytes of the effective address must 
t>e in page zero. 

Indirect Indexed Addressing. In trHlirect indexed address- 
ing (j'eferred to as Indirect, Y), the second byte of the 
irrsffuction points to a memofy location in page zero. The 
contents on this memory location rs added to the contents 
ol the Y index regtster, the resdt beir^ the low-order e^t 
twtsof the eifective address, The carry Irom this addition is 
added to the contents of the nent page zero memory 
location, the result twing the Ngh-order etght bits o* the 
effective address. 

Absolute lndtr«t. The second byte of the instruction con- 
tains the low-order eight bits of a memory location. The 
high-order eight bits of (hat memory location is contained 
in the tNrd byte of the instnjction. The contents of the fuBy 
specified memory location is the low-order byte of the 
effective address. The next inemory location contains the 
high-order byte of the effective address which is loaded 
into ttw 16-bit program counter. 



ASSCHUTE MAXIMUM RATINGS 



■Citing 


Symbol 


Vakic 


Unit 


Supply Vohage 


Vcc 


-0.3 to +7.0 


Vdc 


Input Voltage 




-0.3 to +7.0 


Vdc 


Operating Temperature 




to +70 


°C 


Storage Temperature 


T5TG 


-55 to +150 





CAimoN 

This device conlims input protection igtinu dsrrage due 
to tvgh stMk voitages Of efecfrnf rtekh; however, precxi- 
tions shouki be taken to avoid appiation of va&^es 
Ngfter thin the maxtnum rating. 



MCSfcSOO 



aOCK IIMMC-MCSUIl, 131 14, 15 





-•- Mi* 










- -4 



TIMMC FOR READMG DATA ROM 
MEMOftY OR PeUPtCRAlS 



:x. 



IMNC KM MmnNG DATA TO 



NOTI 

HEF * nmr^ Rclffenrt Parti an dodu. 
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MCS65(I0 



BfCTRlCAL aURACTERISIKS (Vcc - 5.0V ± 5%, V,; = 0, T, - 25''C( 

e,, Bi applies to MC56512, 13, 14, 15, B„(„) Jpptes to MCS6502, 03, 04, 05 and 06 



Symbol 




Min 




Max 


Unit 


Test Condition 


V|H 


Input High Valtage 


Vss + 2.4 

Vcc - 0.2 




Vcc 
Vcc + 0.25 


Vdc 


Logic, a^Ln) 


V, 


Input Low Voltdge 


Vjs - 0.3 
Vss - 0.3 




+ 0.4 
Vss + 0-2 


Vdc 


Logic, a,, |,n, 
81.82 


Vht 


Input High ThreshoW 
Voltage 


Vss + 2.0 






Vdc 


SI5, NMI, ROY, SO, DatJ, 5.0 


VllT 


Ir^^ut Low Threshold 
Voltage 






Vss + 0.8 


Vdc 


RES, NM, RDV. ifilj. Data. S.O. 


*N 


Input Ledkdge Current 






2.5 
100 

mo 


mA 
M 


(Vfj - to 5.25V, Vcc ~ 0| 
Logic (End. RDY, 5.0.) 
81, 


Its 


Three-State (OH State) 
input Current 






10 




(Vf, = 0,4 to 2.4V, Vcc - S.2SV) 
Data Lines 




Output High Vdlage 


Vss + 2 4 






Vdc 


(liO*D = -IOOilMc, Vcc - ■* 75VI 
SYNC. Cusa, A0-A15. R/W 


v<. 


Output Low Voltage 






Vss + OA 


Vdc 


OioAD - 1-6mAdc. Vcc - 
SYNC. Data, AO-AIS, R/W 




Power Dissipation 




.25 


.70 


W 




C 

QxJT 
Cbi 


Capacitance 




» 
50 


10 
15 
12 
50 
SO 
80 


pf 


(Vn = 0, Ts - 25°C, f •= 1MHz) 
Logic 
Data 

A0-A15, R/W, SYNC 
Bl 

B; 



CLOCK T1MI4G— MC56502, 03, 04, 05, 06 




MCS6500 



IMHzTUiVNC 

aOCK TIMMC— MCSU11, 13, 14, IS 



SynM 


awKtnfctk 


Mm 


Typ 


Mai 


Unit 




Cyde Time 


1000 






nsec 


PWH*1 
PWH*2 


Oock Puls« Widtd «1 
(Measured M V^c - 0-2 V) *2 


470 






nsec 


Tp 


Fall Time (Measured from 0.2 V to Vcc - 0.2 V) 






25 


nsec 


To 


Delay Time Between Clocks (Measured at 0.2 V) 









nset 



aOCK TIMMC— MC56S02, 03, M, 05, 06 



SyiiM 


OianKteiisik 




Typ 




Unit 


Tcvc 


Cycle Time 


1000 






ns 


PWH*„ 


^o(n, Pulse Width (measured at 1.S V) 


460 




520 


ns 




*o (w) R'w. fall Tirtw 






10 


ns 


To 


Delay Time Bctweet^ Clocks (measured at 1.5 V) 


5 






ns 


PWH*, 


*i louii P*** Width {measured at 1.5 V) 


PWH+i-20 






ns 


PWH*j 


(OUT, Pulse Width (measured as ).5 V) 


PWH#«,-« 




PWH*^~10 


ns 


T». T, 


*i (out> *i lam Rise, fa' Time 
(measured .8 V to 2.0 V] 
(load - 30pF + 1 TTL) 






25 


m 



UAD/WRm TIMMC 



Symbol 


OurKtefBlk 


Ma 


Typ 


Mu 


Unk 


TrWS 


Read/Write Setup Time From MCS6500 




100 


300 


ns 


Tads 


Address Setup Time From MCS5S0O 




100 


300 


rtt 


Tacc 


Memory Read Access Time 






575 


ns 


Tosu 


Data Statsility Tirrte Period 


1M 






ns 


Tw 


Data Hold Time - Read 


10 






ns 


Tiwtr 


Data Hold Time - Write 


30 


60 




ns 


T«s 


Data Setup Time From MCS65O0 




ISO 


200 


ns 


Trdv 


RDY, S O- Setup Time 


100 






ns 


Tsvuc 


iWC Setup Time From MCS6500 






350 


ns 


Th* 


Address Hold Time 


30 


60 




ns 


TwRW 


R/W How Time 




60 




ns 
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2MHiTlMMG 

CLOCK T1MMC— MCS6SU 13, 14, 15, 16 



Symbol 


Oumtcristic 


Min 


Typ 


Mil 






Cyde Time 


500 






nsec 


PWH*1 
PWH«2 


Clack Pulw Width <»1 
(Mejstred 4t V(^c - 0.2 V) «2 


215 
235 






mec 


Tf 


Fal Time (Mejiired from 0.2 V lo V^c - 02 V) 






12 


nsec 


To 


Deby Tine Between Codes (Measured at 0.2 V) 









nsec 



aOCK T1MNC— MCS6502, 0}, 04, 05, 06 



Symbol 


Chwacttristic 


Min 


Typ 


Max 


UnH 




Cyde Time 


500 






ns 




#0 <ni '^'Ik Widtli (meKured 3t 1.5 V) 


240 




260 


ns 




#1, (Ml Rise, Fall Time 






10 


ns 


To 


Dddy Time Betweefi Clocks (measured at 1.5 V] 


5 






ns 


PVVH#, 


*i touit P'Js* Width (mejswed at 15 V) 








ns 


PWH*; 


*! (OUT) 1^** Width (mcMij-ed at 1.5 V) 


PWH*„„-40 




FWH*oH-10 


ns 


T«.Tp 


*1 (OUT). *! lOUTl f'* fime 
(measured ,6 V to 2.0 V) 
(load - 30pf + 1 TTl) 






25 


ns 



READ/WRITE TIMING 



Symbol 


Chvacterisiic 


Min 


Typ 


Mw 


Unit 


T|tm 


Read/Write Setup Time from MCS65(X)A 




100 


150 


ns 


Tads 


Address Setup Time From MC56500A 




100 


150 


ns 


Tacc 


Memory Read Access Time 






300 


ns 


Tosu 


Data Statvtty Time Peirod 


50 






ns 


Trtt 


Data Hold Time -Read 


10 






ns 


"I^HW 


Data Hold Time - Write 


30 






ns 


TvtjS 


Data Setup Time From MCS6500A 




75 


100 


ns 


Trdv 


RDY. S.O, Setup Time 


50 






ns 


TSVNC 


SYNC Setup Time From MCS6500A 






17S 


ns 


Tha 


Address Hold Time 


30 


60 




ns 


T|«w 


R/W Hold Time 


30 


60 




ns 
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